iOS开发钥匙串保存信息

iOS的keychain服务提供了一种安全的保存私密信息(密码,序列号,证书等)的方式,每个ios程序都有一个独立的keychain存储。相对于NSUserDefaults、文件保存等一般方式,keychain保存更为安全,而且keychain里保存的信息不会因App被删除而丢失,所以在重装App后,keychain里的数据还能使用。从ios 3。0开始,跨程序分享keychain变得可行。


第一步设置钥匙串存储分组:

iOS开发钥匙串保存信息_第1张图片


第二步导入KeychainItemWrapper文件:
KeychainItemWrapper是apple官方例子“GenericKeychain”里一个访问keychain常用操作的封装类,在官网上下载了GenericKeychain项目后,只需要把“KeychainItemWrapper.h”和“KeychainItemWrapper.m”拷贝到我们项目,并导入Security.framework 。
KeychainItemWrapper的apple官方例子地址--https://developer.apple.com/library/ios/samplecode/GenericKeychain/Listings/Classes_KeychainItemWrapper_m.html

iOS开发钥匙串保存信息_第2张图片

第三步设置arc: (-fno-objc-arc)
iOS开发钥匙串保存信息_第3张图片

第四步存储和读取:


存储:

//    其中方法“- (void)setObject:(id)inObject forKey:(id)key;”里参数“forKey”的值应该是Security.framework 里头文件“SecItem.h”里定义好的key,用其他字符串做key程序会崩溃!

     KeychainItemWrapper *wrapper = [[KeychainItemWrapperalloc]initWithIdentifier:@"Username"accessGroup:nil];

       [wrapper setObject :@"account"  forKey :( __bridge id ) kSecAttrAccount ];

读取:

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];


注:要想多个应用共享钥匙串信息可在第一步的分组里进行设置



你可能感兴趣的:(IOS)