一般iOS系统存储的数据都是在sandBox里面, 一旦删除App,沙盒也就不存在了,要想在手机开一只保存用户的个人信息或者个性化设置等信息,及时删除App之后,在此安装还有此信息,那么就可以用keychain(钥匙串)来保存信息
通常情况下,iOS系统用NSUserDefaults存储数据信息, 但是对于一些私密信息, 比如密码,证书等等,就需要使用更为安全的keychain了,
keychain里保存的信息不会因为App被删除而丢失,所以,可以利用这个keychain这个特点来保存设备唯一标识
那么,如何在应用里使用keyChain呢, 我们需要导入Security.framework框架, keyChain的操作接口声明在头文件SecItem.h里.直接使用SecItem.h里面方法操作keychain, 需要写的代码较为复杂, 我们可以使用已经封装好的工具类KeychainItemWrapper来对keychain进行操作. KeychainItemWrapper是apple官方例子中GenericKeychain里一个访问keychain常用的操作的封装类,在官网上下载了GenericKeychain项目后, 只需要把KeychainItemWrapper.h和KeychainItemWrapper.m拷贝到我们自己的工程中,并导入Security.framework框架.
KeychainItemWrapper的用法:
/** 初始化一个保存用户帐号的KeychainItemWrapper */ KeychainItemWrapper *wrapper = [[KeychainItemWrapper alloc] initWithIdentifier:@"Account Number" accessGroup:@"YOUR_APP_ID_HERE.com.yourcompany.AppIdentifier"]; //保存数据 [wrapper setObject:@"<帐号>" forKey:(id)kSecAttrAccount]; [wrapper setObject:@"<帐号密码>" forKey:(id)kSecValueData]; //从keychain里取出帐号密码 NSString *password = [wrapper objectForKey:(id)kSecValueData]; //清空设置 [wrapper resetKeychainItem]; // 其中方法“- (void)setObject:(id)inObject forKey:(id)key;”里参数“forKey”的值应该是Security.framework 里头文件“SecItem.h”里定义好的key,用其他字符串做key程序会出错! KeychainItemWrapper *keychain=[[KeychainItemWrapper alloc] initWithIdentifier:@"xxxxxx" accessGroup:nil];//xxxx 自定义 // 保存 [keyWrapper setObject:@"myChainValues" forKey:(id)kSecAttrService]; [keyWrapper setObject:[usernameTextField text] forKey:(id)kSecAttrAccount];// 上面两行用来标识一个Item [keyWrapper setObject:[passwordTextField text] forKey:(id)kSecValueData]; // 读取 [usernameTextField setText:[keyWrapper objectForKey:(id)kSecAttrAccount]]; [passwordTextField setText:[keyWrapper objectForKey:(id)kSecValueData]];