0

我正在开发几个 iOS 应用程序,我需要在它们之间共享一个元素,我想将其存储在钥匙串中。这个元素用于一个复杂的登录过程,有 3 个或 4 个步骤,在每个步骤中我都需要从钥匙串中读取值,为此我使用了下面的代码:

- (NSString *)installationToken
{
    KeychainItemWrapper *kw = [[KeychainItemWrapper alloc] initWithIdentifier:@"uuid" accessGroup:@"yyyyy.xxxxxxxxxxx"];   

    if (![kw objectForKey:(NSString*)kSecAttrAccount] || [[kw objectForKey:(NSString*)kSecAttrAccount] isEqualToString:@""]) {
        NSString *result;

        CFUUIDRef uuid;
        CFStringRef uuidStr;

        uuid = CFUUIDCreate(NULL);
        assert(uuid != NULL);

        uuidStr = CFUUIDCreateString(NULL, uuid);
        assert(uuidStr != NULL);

        result = [NSString stringWithFormat:@"%@", uuidStr];
        assert(result != nil);

        CFRelease(uuidStr);
        CFRelease(uuid);

        [kw setObject:result forKey:(NSString*)kSecAttrAccount];

        return result;
    } else {
        return [kw objectForKey:(NSString*)kSecAttrAccount];
    }

}

这几乎适用于所有设备,但在某些设备中,用户抱怨。所以,我检查了我的服务器正在接收什么,并看到正在发送不同的值。我检查了代码,在其他地方我没有访问/清空这个钥匙串元素,这有什么问题?对于大多数设备来说,这就像一个魅力,但出于某种原因,在某些设备中,它们不能很好地从钥匙串中存储或检索。问题发生在同一应用程序的不同调用中。

4

1 回答 1

1

如果您使用 Apple 的 KeyChainWrapper 示例代码,那么主要问题有时是随机的,SecItemCopyMatching 失败,然后示例代码有 resetKeychainItem 基本上会重置您的钥匙串。

    if (! SecItemCopyMatching((CFDictionaryRef)tempQuery, (CFTypeRef *)&outDictionary) == noErr)
    {
        // Stick these default values into Keychain if nothing found.
        [self resetKeychainItem];
    }

在我们的应用程序中,我们注意到了类似的问题,所以现在我们正在使用

https://github.com/carlbrown/PDKeychainBindingsController来完成所有与 keyChain 相关的功能。现在它工作得很好。

于 2013-10-01T15:11:52.660 回答