Ios 钥匙链数据未存储在iCloud中
我正在使用钥匙链在本地设备上存储数据,但已决定通过iCloud将其调整为在多个设备上使用。我已启用iCloud授权,并在会员中心内创建了必要的配置。然而,当数据被存储时,它似乎并没有被存储在云中。我正在模拟器和iPhone设备之间进行测试。模拟器使用我的帐户登录。每个设备继续保存数据,但另一个设备看不到结果 我只在现有设置中添加了kSecAttrSynchronizable和kCFBooleanTrue,我知道这是使钥匙链使用云所需的全部 这里是用于存储和调用钥匙链数据的代码Ios 钥匙链数据未存储在iCloud中,ios,objective-c,icloud,keychain,Ios,Objective C,Icloud,Keychain,我正在使用钥匙链在本地设备上存储数据,但已决定通过iCloud将其调整为在多个设备上使用。我已启用iCloud授权,并在会员中心内创建了必要的配置。然而,当数据被存储时,它似乎并没有被存储在云中。我正在模拟器和iPhone设备之间进行测试。模拟器使用我的帐户登录。每个设备继续保存数据,但另一个设备看不到结果 我只在现有设置中添加了kSecAttrSynchronizable和kCFBooleanTrue,我知道这是使钥匙链使用云所需的全部 这里是用于存储和调用钥匙链数据的代码 + (NSMuta
+ (NSMutableDictionary *)getKeychainQuery:(NSString *)service
{
return [NSMutableDictionary dictionaryWithObjectsAndKeys:
(__bridge id)kSecClassGenericPassword,(__bridge id)kSecClass,
service, (__bridge id)kSecAttrService,
service, (__bridge id)kSecAttrAccount,
(__bridge id)kCFBooleanTrue, (__bridge id)kSecAttrSynchronizable,
(__bridge id)kSecAttrAccessibleAfterFirstUnlock,(__bridge id)kSecAttrAccessible,
nil];
}
+ (void)save:(NSString *)service data:(id)data
{
NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];
CFTypeRef result = NULL;
SecItemDelete((__bridge CFDictionaryRef)keychainQuery);
[keychainQuery setObject:[NSKeyedArchiver archivedDataWithRootObject:data] forKey:(__bridge id)kSecValueData];
OSStatus status = SecItemAdd((__bridge CFDictionaryRef)keychainQuery, &result);
if (status == errSecSuccess) NSLog(@"Succcessfully Stored Value");
else NSLog(@"Failed to store value with code: %ld",(long)status);
}
+ (id)load:(NSString *)service {
id ret = nil;
NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];
[keychainQuery setObject:(id)kCFBooleanTrue forKey:(__bridge id)kSecReturnData];
[keychainQuery setObject:(__bridge id)kSecMatchLimitOne forKey:(__bridge id)kSecMatchLimit];
CFDataRef keyData = NULL;
if (SecItemCopyMatching((__bridge CFDictionaryRef)keychainQuery, (CFTypeRef *)&keyData) == noErr) {
@try {
ret = [NSKeyedUnarchiver unarchiveObjectWithData:(__bridge NSData *)keyData];
}
@catch (NSException *e) {
NSLog(@"Unarchive of %@ failed: %@", service, e);
}
@finally {}
}
if (keyData) CFRelease(keyData);
return ret;
}
+ (void)delete:(NSString *)service {
NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];
SecItemDelete((__bridge CFDictionaryRef)keychainQuery);
}
模拟器-版本7.1(463.9.41)-没有(我猜“不模拟”更准确)安全管理钥匙链所需的硬件 你会注意到在iCloud下Settngs.app中的模拟器上没有钥匙链选项,而在设备上有这个选项 如果你深入研究
~/Library/Application Support/iphonesimulator/7.1/Library/Keychains
,你会发现模拟器的钥匙链。对于我放入模拟器钥匙链的所有项目,ksecattraccesgroup
是test
。在设备上运行时,我会获得预期的访问组(我的应用程序的应用程序ID)
所有这些都向我指出了模拟器不支持iCloud钥匙链同步的方向。2014年WWDC会议#711使用触摸ID的钥匙链和身份验证详细介绍了设备的硬件功能如何支持钥匙链加密
两台iOS设备或iOS和OS X是我能够可靠地开发、调试和排除iCloud Keychain sync故障的唯一方法。有点后续。当我在手机上使用应用程序时,我正在Mac上观看钥匙链。我看到钥匙链数据正在被写入,所以它看起来确实在工作。然而,我的印象是模拟器也应该工作,在sim卡的调试下有一个“触发iCloud同步”选项。苹果公司的文件还表明可以使用模拟器。但是,即使在模拟器上输入了我的帐户,它似乎也不会与主钥匙链交互。当您说启用了“iCloud授权”时,您的意思是您已在设置应用程序的“iCloud”下打开钥匙链功能吗?或者在目标设置中的“功能”下启用的pList?中是否需要打开某些翻转。在会员中心,在应用程序ID中添加了“iCloud”(这是他们在“功能”选项卡中引用的权限)。