1. 程式人生 > >ios中KeyChain用途(整理)

ios中KeyChain用途(整理)

一、在應用間利用KeyChain共享資料

我們可以把KeyChain理解為一個Dictionary,所有資料都以key-value的形式儲存,可以對這個Dictionary進行add、update、get、delete這四個操作。對於每一個應用來說,KeyChain都有兩個訪問區,私有區和公共區。私有區是一個sandbox,本程式儲存的任何資料都對其他程式不可見。而要想在將儲存的內容放在公共區,需要先宣告公共區的名稱,官方文件管這個名稱叫“keychain access group”,宣告的方法是新建一個plist檔案,名字隨便起,內容如下:

“yourAppID.com.yourCompany.whatever”就是你要起的公共區名稱,除了whatever欄位可以隨便定之外,其他的都必須如實填寫。這個檔案的路徑要配置在 Project->build setting->Code Signing Entitlements裡,否則公共區無效,配置好後,須用你正式的證書籤名編譯才可通過,否則xcode會彈框告訴你code signing有問題。所以,蘋果限制了你只能同公司的產品共享KeyChain資料,別的公司訪問不了你公司產品的KeyChain。

二、儲存私密資訊

iOS的keychain服務提供了一種安全的儲存私密資訊(密碼,序列號,證書等)的方式,每個ios程式都有一個獨立的keychain儲存。相對於NSUserDefaults、檔案儲存等一般方式,keychain儲存更為安全,而且keychain裡儲存的資訊不會因App被刪除而丟失,所以在重灌App後,keychain裡的資料還能使用。 在應用裡使用使用keyChain,我們需要匯入Security.framework ,keychain的操作介面宣告在標頭檔案SecItem.h裡。直接使用SecItem.h裡方法操作keychain,需要寫的程式碼較為複雜,為減輕咱們程式設計師的開發,我們可以使用一些已經封裝好了的工具類,下面我會簡單介紹下我用過的兩個工具類:KeychainItemWrapper和SFHFKeychainUtils。

(一)KeychainItemWrapper

下載地址:http://download.csdn.net/detail/u011439689/6877641
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程式會崩潰!

(二)SFHFKeychainUtils 提供了在 iOS keychain中安全的儲存密碼的工具
1、引入Security.frameWork框架。 2、引入標頭檔案:SFHKeychainUtils.h. 3、存密碼: [SFHFKeychainUtils storeUsername:@"dd" andPassword:@"aa"forServiceName:SERVICE_NAME updateExisting:1 error:nil]; [SFHFKeychainUtils deleteItemForUsername:@"dd" andServiceName:SERVICE_NAME error:nil]; 4、取密碼: NSString *passWord =  [SFHFKeychainUtils getPasswordForUsername:@"dd"andServiceName:SERVICE_NAME error:nil];