我对iOS开发非常陌生,所以请原谅我,如果这是一个新手问题。我有一个简单的身份验证机制来接收用户的电子邮件地址和密码。我也有一个开关说'记住我'。如果用户切换开关,我想保留他们的电子邮件/密码,以便将来可以自动填充这些字段。在iOS中保存电子邮件/密码到钥匙串
我已经得到这个工作与保存到plist文件,但我知道这不是最好的主意,因为密码是未加密的。我发现了一些用于保存钥匙串的示例代码,但说实话,我有点迷路。对于下面的功能,我不知道如何调用它以及如何修改它以保存电子邮件地址。
我猜打电话给那就是:saveString(@"passwordgoeshere");
感谢您的帮助!
+ (void)saveString:(NSString *)inputString forKey:(NSString *)account {
NSAssert(account != nil, @"Invalid account");
NSAssert(inputString != nil, @"Invalid string");
NSMutableDictionary *query = [NSMutableDictionary dictionary];
[query setObject:(id)kSecClassGenericPassword forKey:(id)kSecClass];
[query setObject:account forKey:(id)kSecAttrAccount];
[query setObject:(id)kSecAttrAccessibleWhenUnlocked forKey:(id)kSecAttrAccessible];
OSStatus error = SecItemCopyMatching((CFDictionaryRef)query, NULL);
if (error == errSecSuccess) {
// do update
NSDictionary *attributesToUpdate = [NSDictionary dictionaryWithObject:[inputString dataUsingEncoding:NSUTF8StringEncoding]
forKey:(id)kSecValueData];
error = SecItemUpdate((CFDictionaryRef)query, (CFDictionaryRef)attributesToUpdate);
NSAssert1(error == errSecSuccess, @"SecItemUpdate failed: %d", error);
} else if (error == errSecItemNotFound) {
// do add
[query setObject:[inputString dataUsingEncoding:NSUTF8StringEncoding] forKey:(id)kSecValueData];
error = SecItemAdd((CFDictionaryRef)query, NULL);
NSAssert1(error == errSecSuccess, @"SecItemAdd failed: %d", error);
} else {
NSAssert1(NO, @"SecItemCopyMatching failed: %d", error);
}
}
我固定@失范的代码与ARC工作,并把它在Github上(我链接到这个答案,并在这两个文件中提到你的用户,但如果你想了解更多的归因,请让我知道)。我也改变了一些格式,使得方法名称更通用一些。 https://github.com/jeremangnr/JNKeychain – jere 2013-05-13 15:37:22