我想在钥匙串(keychain)中存储值“MyKeyValue”,我这样做:
NSData* key = [@"MyKeyValue" dataUsingEncoding:NSUTF8StringEncoding];
NSData* tag = [@"com.example.MyKey" dataUsingEncoding:NSUTF8StringEncoding];
NSDictionary* addquery = @{ (id)kSecValueRef: key,
(id)kSecClass: (id)kSecClassKey,
(id)kSecAttrApplicationTag: tag,
};
OSStatus status = SecItemAdd((__bridge CFDictionaryRef)addquery, NULL);
但这失败了,错误为 -50(无效参数) 我做错了什么?
我想在钥匙串(keychain)中存储一个字符串,如果用户卸载并重新安装我的应用程序可以检索该字符串。
最佳答案
错误是由于 kSecValueRef
而发生的,根据 Apple 的指南 kSecValueRef
接受可以通过 SecKeyRef
生成的加密 key ,请查找下面,
NSData* tag = [@"com.example.keys.mykey" dataUsingEncoding:NSUTF8StringEncoding];
NSDictionary* attributes =
@{ (id)kSecAttrKeyType: (id)kSecAttrKeyTypeRSA,
(id)kSecAttrKeySizeInBits: @2048,
(id)kSecPrivateKeyAttrs:
@{ (id)kSecAttrIsPermanent: @YES,
(id)kSecAttrApplicationTag: tag,
},
};
CFErrorRef error = NULL;
SecKeyRef privateKey = SecKeyCreateRandomKey((__bridge CFDictionaryRef)attributes,
&error);
SecKeyRef publicKey = SecKeyCopyPublicKey(privateKey);
NSDictionary* addquery = @{ (id)kSecValueRef: (__bridge id)publicKey,
(id)kSecClass: (id)kSecClassKey,
(id)kSecAttrApplicationTag: tag,
};
OSStatus status = SecItemAdd((__bridge CFDictionaryRef)addquery, NULL);
更多信息请引用Storing Keys in the Keychain
关于ios - 为什么 SecItemAdd 返回 -50(无效参数),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49635716/