OC中 Null 与 nil的区别

NULL是指指针是空值,用来判断C 指针;

nil是指一个OC对象(指针)为空;

Nil是指一个OC类为空;

NSNull则用于填充集合元素;这个类只有一个方法null,并且是单例的;

虽然它们表示的都是空值,但使用场合完全不同,所以在编码时要严格按照变量类型来赋值;


还有BOOL 和bool也一并说了吧:

BOOL 其实是定义出来的,并不是OC的对象,他的本质是unsigned char ,所以能存储0-255的数字;

bool 是做过处理的只能存储0或者1;


顺便id也提提吧

id也是定义出来的,原型是结构体指针,所以我们在使用时就不用带‘*’了,说白了OC的对象底层都是通过结构存储的,然后在结构体之间建立关系,那就是OC的继承体系了;


关于定义类型有很多,比如NSInteger等等;

我们也可以自己定义,使用typedef即可;

在使用公钥加密时,一般是使用公钥加密数据,然后使用私钥解密,因此在接收到服务器返回的加密数据时,你需要使用相应的私钥进行解密。 具体步骤如下: 1. 首先,将从服务器接收到的加密数据进行Base64解码,得到原始的加密数据。 2. 然后,使用OC中的 SecKey 从文件或字符串中导入私钥。 3. 接着,使用私钥对原始数据进行解密,得到明文数据。 以下是一个示例代码: ```objective-c // 从服务器获取的加密数据 NSString *encryptedData = @"..."; // 将加密数据进行Base64解码 NSData *encryptedDataDecoded = [[NSData alloc] initWithBase64EncodedString:encryptedData options:0]; // 导入私钥 NSString *privateKeyPath = [[NSBundle mainBundle] pathForResource:@"private_key" ofType:@"p12"]; NSData *privateKeyData = [[NSData alloc] initWithContentsOfFile:privateKeyPath]; NSDictionary *options = @{(__bridge id)kSecImportExportPassphrase: @"password"}; CFArrayRef items = NULL; OSStatus securityError = SecPKCS12Import((__bridge CFDataRef)privateKeyData, (__bridge CFDictionaryRef)options, &items); if (securityError == noErr && CFArrayGetCount(items) > 0) { CFDictionaryRef identityDict = CFArrayGetValueAtIndex(items, 0); SecIdentityRef identityApp = (SecIdentityRef)CFDictionaryGetValue(identityDict, kSecImportItemIdentity); SecKeyRef privateKeyRef; SecIdentityCopyPrivateKey(identityApp, &privateKeyRef); // 使用私钥解密数据 size_t plainBufferSize = SecKeyGetBlockSize(privateKeyRef); uint8_t *plainBuffer = malloc(plainBufferSize); memset(plainBuffer, 0, plainBufferSize); OSStatus status = SecKeyDecrypt(privateKeyRef, kSecPaddingPKCS1, encryptedDataDecoded.bytes, encryptedDataDecoded.length, plainBuffer, &plainBufferSize); NSData *decryptedData = nil; if (status == noErr) { decryptedData = [[NSData alloc] initWithBytes:plainBuffer length:plainBufferSize]; } free(plainBuffer); // 显示解密后的数据 if (decryptedData) { NSString *decryptedString = [[NSString alloc] initWithData:decryptedData encoding:NSUTF8StringEncoding]; NSLog(@"解密后的数据:%@", decryptedString); } CFRelease(privateKeyRef); } CFRelease(items); ``` 注意,在上面的代码中,我使用了一个证书文件(private_key.p12)来导入私钥。在实际应用中,你需要使用你自己的证书文件。同时,你也需要替换其中的密码证书文件名。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值