iOS开发钥匙串保存信息

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


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




第二步导入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



第三步设置arc: (-fno-objc-arc)


第四步存储和读取:


存储:

//    其中方法“- (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];


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



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值