KeychainItemWrapper не загружается на iOS 9 OSStatus -34018 (errSecMissingEntitlement)
Я использовал KeychainItemWrapper просто отлично. Но поскольку я обновил свой телефон до iOS 9, по какой-то причине он не сохраняет идентификатор сессии.
+ (BOOL)createKeychainValue:(NSString *)value forIdentifier:(NSString *)identifier
{
NSMutableDictionary *dictionary = [self setupSearchDirectoryForIdentifier:identifier];
NSData *valueData = [value dataUsingEncoding:NSUTF8StringEncoding];
[dictionary setObject:valueData forKey:(__bridge id)kSecValueData];
// Protect the keychain entry so it's only valid when the device is unlocked at least once.
[dictionary setObject:(__bridge id)kSecAttrAccessibleAfterFirstUnlockThisDeviceOnly forKey:(__bridge id)kSecAttrAccessible];
// **THIS LINE OF CODE RETURNS -34108**
OSStatus status = SecItemAdd((__bridge CFDictionaryRef)dictionary, NULL);
// If the addition was successful, return. Otherwise, attempt to update existing key or quit (return NO).
if (status == errSecSuccess) {
return YES;
} else if (status == errSecDuplicateItem){
return [self updateKeychainValue:value forIdentifier:identifier];
} else {
return NO; **The call returns here...**
}
}
Кто-нибудь знает, что происходит?
РЕДАКТИРОВАТЬ
Самое странное: это происходит только время от времени и всегда в режиме отладки.
EDIT2
Поскольку это происходит только в режиме отладки, есть два обходных пути, которые я обычно делаю в зависимости от типа переменной: - Всегда сохраняйте последнюю действительную переменную, загруженную из цепочки для ключей локально (например, sessionID), и используйте ее в качестве резервной копии, когда в режим отладки - игнорируйте недопустимые значения, если это возможно, при отладке (в этом случае я бы добавил дополнительную переменную управления, чтобы разрешить / запретить эти недопустимые значения)
(используйте #ifdef DEBUG, чтобы проверить, находитесь ли вы в режиме отладки)
1 ответ
По словам Apple, сейчас нет решения. https://forums.developer.apple.com/thread/4743