10

私のアプリでは、ユーザーが作成した構成を同期できるようにしたいと考えています。iCloudを使用してその構成を同期し、すべてのデバイスで常に同じになるようにしたかったのです。しかし、私はパスワードを保存するためにキーチェーンを使用しています。

キーチェーンデータも同期する方法はありますか?

4

4 に答える 4

20

iCloudキーチェーンは、iOS7.0.3およびOSXMavericks10.9の新機能です。kSecAttrSynchronizableSecItemAPIを使用してキーチェーンアイテムを追加するときに属性を指定します。

于 2013-10-27T18:41:34.763 に答える
5

これらは私がキーチェーンのために作ったユーティリティメソッドです。kSecAttrSynchronizableは、iCloudSyncを機能させるものです。彼らが助けてくれることを願っています。

  • キーチェーンクエリ。
  • アイテムを削除
  • アイテムを削除
  • アイテムを保存
  • アイテムをロード

    + (NSMutableDictionary *)getKeychainQuery:(NSString *)service {
        return [NSMutableDictionary dictionaryWithObjectsAndKeys:
                (__bridge id)kSecClassGenericPassword, (__bridge id)kSecClass,
                service, (__bridge id)kSecAttrService,
                service, (__bridge id)kSecAttrAccount,
                service, (__bridge id)kSecAttrSynchronizable,
                (__bridge id)kSecAttrAccessibleAfterFirstUnlock, (__bridge id)kSecAttrAccessible,
                nil];
    }
    
    + (void)save:(NSString *)service data:(id)data {
        NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];
        SecItemDelete((__bridge CFDictionaryRef)keychainQuery);
        [keychainQuery setObject:[NSKeyedArchiver archivedDataWithRootObject:data] forKey:(__bridge id)kSecValueData];
        SecItemAdd((__bridge CFDictionaryRef)keychainQuery, NULL);
    }
    
    + (void)remove:(NSString *)service {
         NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];
         SecItemDelete((__bridge CFDictionaryRef)keychainQuery);
    }
    
    +(NSString *)keychainItem:(NSString *)service{
        id data = [self load:service];
    
        if([data isKindOfClass:[NSString class]]){
            return data;
        }
        return @"";
    }
    
    + (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;
    }
    
于 2015-09-16T10:43:00.503 に答える
3

いいえ、キーチェーンの同期はiCloudの一部ではありません。これはドットマック同期の一部でしたが、現在は使用できません。

これが良いアイデアかどうか(あるデバイスから別のデバイスにパスワードを自動的に移動する)、特に複数の人がiCloudアカウントを共有している状況(最近は保証されていない可能性が高い)については、おそらくフィードバックがあります。

パスワードをデバイスのキーチェーンに保存していると思われる場合(したがって、ユーザーがデバイスごとに少なくとも1回パスワードを入力する必要がある場合)、独自の暗号化と安全性を提供し、データをiCloudに直接保存する必要があります。キーストア。

于 2012-07-15T11:44:24.933 に答える
0

同じことをしようとしていますが、まだ試していませんが、これは役に立ちそうです:https ://github.com/iosengineer/BMCredentials

于 2015-11-10T02:29:39.500 に答える