Xcode からデバイス上でアプリケーションを実行すると、キーチェーンにアクセスしようとしても、エラー -34018 が原因で失敗することがあります。これは、文書化されているキーチェーン エラー コードのいずれとも一致せず、一貫して再現することはできません。(おそらく30%の確率で発生しますが、なぜ発生するのかはわかりません)。この問題のデバッグを非常に困難にしているのは、ドキュメントがまったくないことです。これの原因とそれを修正する方法はありますか?Xcode 5 を使用しており、デバイスで iOS 7.0.4 を実行しています。
これに関する未解決の問題があります: https://github.com/soffes/sskeychain/issues/52
編集: リクエストごとにキーチェーン アクセス コードを追加する
SSKeychain
キーチェーンとのインターフェースにライブラリを使用しています。これがスニペットです。
#define SERVICE @"default"
@implementation SSKeychain (EXT)
+ (void)setValue:(NSString *)value forKey:(NSString *)key {
NSError *error = nil;
BOOL success = NO;
if (value) {
success = [self setPassword:value forService:SERVICE account:key error:&error];
} else {
success = [self deletePasswordForService:SERVICE account:key error:&error];
}
NSAssert(success, @"Unable to set keychain value %@ for key %@ error %@", value, key, error);
if (!success) {
LogError(@"Unable to set value to keychain %@", error);
}
LogTrace(@"Will set keychain account %@. is to nil? %d", key, value == nil);
if (value == nil)
LogWarn(@"Setting keychain %@ to nil!!!", key);
}
+ (NSString *)valueForKey:(NSString *)key {
NSError *error = nil;
NSString *value = [self passwordForService:SERVICE account:key error:&error];
if (error && error.code != errSecItemNotFound) {
NSAssert(!error, @"Unable to retrieve keychain value for key %@ error %@", key, error);
LogError(@"Unable to retrieve keychain value for key %@ error %@", key, error);
}
return value;
}
+ (BOOL)removeAllValues {
LogInfo(@"Completely Reseting Keychain");
return [[self accountsForService:SERVICE] all:^BOOL(NSDictionary *accountInfo) {
return [self deletePasswordForService:SERVICE account:accountInfo[@"acct"]];
}];
}
@end
ほとんどの場合、それで問題ありません。キーチェーンへの書き込みまたはキーチェーンからの読み取りができないアサーション エラーが発生し、重大なアサーション エラーが発生することがあります。