苹果在他们的GenericKeyChain样本代码中提供了GenericKeyChain样本代码类。在SO上有一个ARC编辑的解决方案,我试图遵循这个解决方案:包装器存储在KeyChain on iOS上。
包装器的用法如下:
KeychainItemWrapper *keychain = [[KeychainItemWrapper alloc] initWithIdentifier:@"F11-email-auth" accessGroup:nil];
[keychain setObject:[emailTextfield text] forKey:(__bridge id)(kSecMatchEmailAddressIfPresent)];
[keychain setObject:[passwordTextfield text] forKey:(__bridge id)(kSecClassGenericPassword)];接受带有电子邮件文本字段的行。但是,带有密码的第二行崩溃,例外情况如下。
Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Couldn't add the Keychain Item.'
*** First throw call stack:
(
0 CoreFoundation 0x01b445e4 __exceptionPreprocess + 180
1 libobjc.A.dylib 0x018c78b6 objc_exception_throw + 44
2 CoreFoundation 0x01b44448 +[NSException raise:format:arguments:] + 136
3 Foundation 0x014a823e -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 116
4 Feeltracker 0x000053b3 -[KeychainItemWrapper writeToKeychain] + 899
5 Feeltracker 0x00004700 -[KeychainItemWrapper setObject:forKey:] + 272
6 Feeltracker 0x000092d6 -[FTLoginViewController connectToAccount:] + 374
7 libobjc.A.dylib 0x018d9874 -可能是什么原因?我想知道它是否与我使用的常量有关。
更新:
多亏了罗曼底的帮助:
这一点似乎会抛出错误:
// No previous item found; add the new one.
result = SecItemAdd((__bridge CFDictionaryRef)[self dictionaryToSecItemFormat:keychainItemData], NULL);
NSAssert( result == noErr, @"Couldn't add the Keychain Item." );结果是-50。SecItemAdd是一个lib方法。正如我所预料的,这与KeyChain的直接处理有关.
keychainItemData包含:

发布于 2013-11-07 09:48:24
我不能再得到这个苹果的例子,因为密钥链包装器的工作。幸运的是,对这个问题的进一步研究揭示了这个解决方案,它对我是有效的。
请注意,解决方案的最初答案不是ARC‘’ed,但是有人如此好心地创建了一个Github上的弧形版本。我用了那个,效果很好。
它是一个围绕密钥链的包装器,它的工作甚至比原来的更简单。
希望这能帮助其他有类似问题的人。
发布于 2016-10-10 20:43:19
在模拟器上运行应用程序时,我也犯了同样的错误,但它在设备上工作得很好。
为了解决模拟器的问题,我不得不打开“共享密钥链权限”。
共享密钥链权利
https://stackoverflow.com/questions/19749160
复制相似问题