IOS開發之----兩種保存用戶名和密碼實現記住密碼庫

使用Keychain存儲用戶敏感信息

iOS的keychain服務提供了一種安全的保存私密信息(密碼,序列號,證書等)的方式,每一個ios程序都有一個獨立的keychain存儲。相對於 NSUserDefaults、文件保存等通常方式,keychain保存更爲安全,並且keychain裏保存的信息不會因App被刪除而丟失,因此在 重裝App後,keychain裏的數據還能使用。從ios 3。0開始,跨程序分享keychain變得可行。html

如何須要在應用裏使用使用keyChain,咱們須要導入Security.framework ,keychain的操做接口聲明在頭文件SecItem.h裏。直接使用SecItem.h裏方法操做keychain,須要寫的代碼較爲複雜,爲減輕我們程序員的開發,咱們能夠使用一些已經封裝好了的工具類,下面我會簡單介紹下我用過的兩個工具類:KeychainItemWrapper和SFHFKeychainUtils。ios

KeychainItemWrapper (下載)

KeychainItemWrapper是apple官方例子「GenericKeychain」裏一個訪問keychain經常使用操做的封裝類,在官網上下載了GenericKeychain項目後,只須要把「KeychainItemWrapper.h」和「KeychainItemWrapper.m」拷貝到咱們項目,並導入Security.framework 。KeychainItemWrapper的用法:git

 
  1.   
  2. KeychainItemWrapper *wrapper = [[KeychainItemWrapper alloc] initWithIdentifier:@"Account Number"    
  3.                                                                    accessGroup:@"YOUR_APP_ID_HERE.com.yourcompany.AppIdentifier"];   
  4.   
  5. //保存賬號   
  6. [wrapper setObject:@"<賬號>" forKey:(id)kSecAttrAccount];     
  7.        
  8. //保存密碼   
  9. [wrapper setObject:@"<賬號密碼>" forKey:(id)kSecValueData];     
  10.        
  11. //從keychain裏取出賬號密碼   
  12. NSString *password = [wrapper objectForKey:(id)kSecValueData];       
  13.   
  14. //清空設置   
  15. [wrapper resetKeychainItem];   

另外須要引入Security.framework 和KeychainItemWrapper頭文件程序員

其中方法「- (void)setObject:(id)inObject forKey:(id)key;」裏參數「forKey」的值應該是Security.framework 裏頭文件「SecItem.h」裏定義好的key,用其餘字符串作key程序會崩潰!github

 

SFHFKeychainUtils(下載)

SFHFKeychainUtils是另外一個封裝了KeyChain簡單操做的第三方類庫,使用上比KeychainItemWrapper要簡單點,SFHFKeychainUtils只提供了獲取、保存和刪除三個方法:安全

  1. #import    
  2.   
  3. @interface SFHFKeychainUtils : NSObject {   
  4.        
  5. }   
  6.   
  7.   
  8. + (NSString *) getPasswordForUsername: (NSString *) username andServiceName: (NSString *) serviceName error: (NSError **) error;   
  9.   
  10.   
  11. + (BOOL) storeUsername: (NSString *) username andPassword: (NSString *) password forServiceName: (NSString *) serviceName updateExisting: (BOOL) updateExisting error: (NSError **) error;   
  12.   
  13.   
  14. + (BOOL) deleteItemForUsername: (NSString *) username andServiceName: (NSString *) serviceName error: (NSError **) error;   
  15.   
  16. @end  
 

使用方法:

  1. #define ServiceName @"com.mycompany.yourAppServiceName"   
  2.   
  3. NSError *error;   
  4. NSString *userName = @"<用戶名>";   
  5. NSString *password = @"<用戶密碼>";   
  6.        
  7.   
  8. BOOL saved = [SFHFKeychainUtils storeUsername:userName   
  9.                                   andPassword:password    
  10.                                forServiceName:ServiceName    
  11.                                updateExisting:YES    
  12.                                      error:&error ];   
  13. if (!saved) {   
  14.     NSLog(@"保存密碼時出錯:%@", error);   
  15. }   
  16.        
  17. error = nil;   
  18. NSString *thePassword = [SFHFKeychainUtils getPasswordForUsername:userName    
  19.                                                    andServiceName:ServiceName    
  20.                                                             error:&error];   
  21. if(error){   
  22.     NSLog(@"從Keychain裏獲取密碼出錯:%@", error);   
  23. }   

 

SSKeyChains對蘋果安全框架API進行了簡單封裝,支持對存儲在鑰匙串中密碼、 帳戶進行訪問,包括讀取、刪除和設置。app

https://github.com/soffes/sskeychain框架

http://netmera.com/netmera-resources/doc/ios/v_1.5.1/Classes/SSKeychain.html#overview工具

相關文章
相關標籤/搜索