如何使用iOS Keychain儲存使用者重要訊息

來源:互聯網
上載者:User

標籤:

iOS的keychain服務提供了一種安全的儲存私密資訊(密碼,序號,認證等)的方式,每個ios程式都有一個獨立的keychain儲存。相對於NSUserDefaults、檔案儲存等一般方式,keychain儲存更為安全,而且keychain裡儲存的資訊不會因App被刪除而丟失,所以在重裝App後,keychain裡的資料還能使用。從ios 3。0開始,跨程式分享keychain變得可行。

  如何需要在應用裡使用使用keyChain,我們需要匯入Security.framework ,keychain的操作介面聲明在標頭檔SecItem.h裡。直接使用SecItem.h裡方法操作keychain,需要寫的代碼較為複雜,為減輕咱們程式員的開發,我們可以使用一些已經封裝好了的工具類,下面我會簡單介紹下我用過的兩個工具類:KeychainItemWrapper和SFHFKeychainUtils。

  KeychainItemWrapper (下載)
  KeychainItemWrapper是apple官方例子“GenericKeychain”裡一個訪問keychain常用操作的封裝類,在官網上下載了GenericKeychain項目後,只需要把“KeychainItemWrapper.h”和“KeychainItemWrapper.m”拷貝到我們項目,並匯入Security.framework 。KeychainItemWrapper的用法:

  [html] view plaincopy
  /** 初始化一個儲存使用者帳號的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(下載)
  SFHFKeychainUtils是另一個封裝了KeyChain簡單操作的第三方類庫,使用上比KeychainItemWrapper要簡單點,SFHFKeychainUtils只提供了擷取、儲存和刪除三個方法:

  [html] view plaincopy
  #import <UIKit/UIKit.h>
  
  @interface SFHFKeychainUtils : NSObject {
  
  }
  
  /** 從Keychain裡擷取使用者密碼
  *param username 使用者名稱
  *param serviceName 服務名
  *return NSString 使用者名稱對應的密碼
  */
  + (NSString *) getPasswordForUsername: (NSString *) username andServiceName: (NSString *) serviceName error: (NSError **) error;
  
  /**
  *把使用者的密碼儲存到Keychain裡
  *@param username 使用者名稱
  *@param password 要儲存的密碼
  *@param serviceName 本條keychains所屬的服務(組)
  *return BOOL 是否儲存成功
  */
  + (BOOL) storeUsername: (NSString *) username andPassword: (NSString *) password forServiceName: (NSString *) serviceName updateExisting: (BOOL) updateExisting error: (NSError **) error;
  
  /**
  * 刪除某個使用者資訊
  *param username 使用者名稱
  *param serviceName 使用者所屬的服務(組)
  *return BOOL 是否刪除成功
  */
  + (BOOL) deleteItemForUsername: (NSString *) username andServiceName: (NSString *) serviceName error: (NSError **) error;
  
  @end
  使用方法:
  [html] view plaincopy
  #define ServiceName @"com.mycompany.yourAppServiceName"
  NSError *error;
  NSString *userName = @"<使用者名稱>";
  NSString *password = @"<使用者密碼>";
  
  /** 儲存使用者的密碼*/
  BOOL saved = [SFHFKeychainUtils storeUsername:userName
  andPassword:password
  forServiceName:ServiceName
  updateExisting:YES
  error:&error ];
  if (!saved) {
  NSLog(@"儲存密碼時出錯:%@", error);
  }
  
  error = nil;
  NSString *thePassword = [SFHFKeychainUtils getPasswordForUsername:userName
  andServiceName:ServiceName
  error:&error];
  if(error){
  NSLog(@"從Keychain裡擷取密碼出錯:%@", error);
  }

如何使用iOS Keychain儲存使用者重要訊息

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.