由於IOS系統存儲的數據都是在sandBox裡面,一旦刪除App,sandBox也不復存在。好在有一個例外,那就是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=[[KeychainItemWrapperalloc]initWithIdentifier:@"AccountNumber" accessGroup:@"YOUR_APP_ID_HERE.com.yourcompany.AppIdentifier"]; //保存數據 [wrappersetObject:@"<帳號>"forKey:(id)kSecAttrAccount]; [wrappersetObject:@"<帳號密碼>"forKey:(id)kSecValueData]; //從keychain裡取出帳號密碼 NSString*password=[wrapperobjectForKey:(id)kSecValueData]; //清空設置 [wrapperresetKeychainItem];其中方法“-(void)setObject:(id)inObjectforKey:(id)key;”裡參數“forKey”的值應該是Security.framework裡頭文件“SecItem.h”裡定義好的key,用其他字符串做key程序會出錯!
————————————————————————————————————————————————————————————————————————————————————————
————————————————————————————————————————————————————————————————————————————————————————
直接貼代碼
KeychainItemWrapper*keychain=[[KeychainItemWrapperalloc]initWithIdentifier:@"xxxxxx"accessGroup:nil];//xxxx 自定義
保存
[keyWrappersetObject:@"myChainValues"forKey:(id)kSecAttrService];
[keyWrappersetObject:[usernameTextFieldtext]forKey:(id)kSecAttrAccount];// 上面兩行用來標識一個Item
[keyWrappersetObject:[passwordTextFieldtext]forKey:(id)kSecValueData];
讀取
[usernameTextFieldsetText:[keyWrapperobjectForKey:(id)kSecAttrAccount]];
[passwordTextFieldsetText:[keyWrapperobjectForKey:(id)kSecValueData]];