iOS的keychain服务提供了一种安全的保存私密信息(密码,序列号,证书等)的方式,每个ios程序都有一个独立的keychain存储。相对于NSUserDefaults、文件保存等一般方式,keychain保存更为安全,而且keychain里保存的信息不会因App被删除而丢失,所以在重装App后,keychain里的数据还能使用。从ios 3。0开始,跨程序分享keychain变得可行。
第一步设置钥匙串存储分组:
// 其中方法“- (void)setObject:(id)inObject forKey:(id)key;”里参数“forKey”的值应该是Security.framework 里头文件“SecItem.h”里定义好的key,用其他字符串做key程序会崩溃!
KeychainItemWrapper *wrapper = [[KeychainItemWrapperalloc]initWithIdentifier:@"Username"accessGroup:nil];
NSString *account = [wrapperobjectForKey:(__bridgeid)kSecAttrAccount];
清空信息:
[wrapper resetKeychainItem];
// //保存帐号
// [wrapper setObject:@"<帐号>" forKey:(__bridge id)kSecAttrAccount];
// //保存密码
// [wrapper setObject:@"<帐号密码>" forKey:(__bridge id)kSecValueData];
// //从keychain里取出帐号密码
// NSString *password = [wrapper objectForKey:(__bridge id)kSecValueData];
注:要想多个应用共享钥匙串信息可在第一步的分组里进行设置