keychain使用介绍

转载 2013年12月03日 11:06:04

 iOSkeychain服务提供了一种安全的保存私密信息(密码,序列号,证书等)的方式。每个ios程序都有一个独立的keychain存储。从ios 3.0开始,跨程序分享keychain变得可行。

使用苹果官方发布的KeychainItemWrapper或者SFHFKeychainUtils很方便。

苹果已经有现成的类封装好了keychain,KeychainItemWrapper.hKeychainItemWrapper.m文件,可以在GenericKeychain实例里找到。

下面就使用keychain来实现存取用户名和密码。

代码如下:

CHKeychain.h

  1. #import <Foundation/Foundation.h>  
  2. #import <Security/Security.h>  
  3.   
  4.   
  5. @interface CHKeychain : NSObject  
  6.   
  7. + (void)save:(NSString *)service data:(id)data;  
  8. + (id)load:(NSString *)service;  
  9. + (void)delete:(NSString *)service;  
  10.   
  11.   
  12. @end  


CHKeychain.m

  1. #import "CHKeychain.h"  
  2.   
  3. @implementation CHKeychain  
  4. + (NSMutableDictionary *)getKeychainQuery:(NSString *)service {  
  5.     return [NSMutableDictionary dictionaryWithObjectsAndKeys:  
  6.             (id)kSecClassGenericPassword,(id)kSecClass,  
  7.             service, (id)kSecAttrService,  
  8.             service, (id)kSecAttrAccount,  
  9.             (id)kSecAttrAccessibleAfterFirstUnlock,(id)kSecAttrAccessible,  
  10.             nil];  
  11. }  
  12.   
  13. + (void)save:(NSString *)service data:(id)data {  
  14.     //Get search dictionary  
  15.     NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];  
  16.     //Delete old item before add new item  
  17.     SecItemDelete((CFDictionaryRef)keychainQuery);  
  18.     //Add new object to search dictionary(Attention:the data format)  
  19.     [keychainQuery setObject:[NSKeyedArchiver archivedDataWithRootObject:data] forKey:(id)kSecValueData];  
  20.     //Add item to keychain with the search dictionary  
  21.     SecItemAdd((CFDictionaryRef)keychainQuery, NULL);  
  22. }  
  23.   
  24. + (id)load:(NSString *)service {  
  25.     id ret = nil;  
  26.     NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];  
  27.     //Configure the search setting  
  28.     //Since in our simple case we are expecting only a single attribute to be returned (the password) we can set the attribute kSecReturnData to kCFBooleanTrue  
  29.     [keychainQuery setObject:(id)kCFBooleanTrue forKey:(id)kSecReturnData];  
  30.     [keychainQuery setObject:(id)kSecMatchLimitOne forKey:(id)kSecMatchLimit];  
  31.     CFDataRef keyData = NULL;  
  32.     if (SecItemCopyMatching((CFDictionaryRef)keychainQuery, (CFTypeRef *)&keyData) == noErr) {  
  33.         @try {  
  34.             ret = [NSKeyedUnarchiver unarchiveObjectWithData:(NSData *)keyData];  
  35.         } @catch (NSException *e) {  
  36.             NSLog(@"Unarchive of %@ failed: %@", service, e);  
  37.         } @finally {  
  38. }  
  39.     }  
  40.     if (keyData)   
  41.     CFRelease(keyData);  
  42.     return ret;  
  43. }  
  44.   
  45. + (void)delete:(NSString *)service {  
  46.     NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];  
  47.     SecItemDelete((CFDictionaryRef)keychainQuery);  
  48. }  
  49.   
  50.   
  51. @end  


首先需要定义几个字符串用来做key

  1. NSString * const KEY_USERNAME_PASSWORD = @"com.company.app.usernamepassword";  
  2. NSString * const KEY_USERNAME = @"com.company.app.username";  
  3. NSString * const KEY_PASSWORD = @"com.company.app.password";  

把用户名和密码存入keychain

  1. NSMutableDictionary *usernamepasswordKVPairs = [NSMutableDictionary dictionary];  
  2. [usernamepasswordKVPairs setObject:txtfldUsername.text forKey:KEY_USERNAME];  
  3. [usernamepasswordKVPairs setObject:txtfldPassword.text forKey:KEY_PASSWORD];  
  4. [CHKeychain save:KEY_USERNAME_PASSWORD data:usernamepasswordKVPairs];  

keychain中取出用户名和密码:

  1. NSMutableDictionary *usernamepasswordKVPairs = (NSMutableDictionary *)[CHKeychain load:KEY_USERNAME_PASSWORD];  
  2. txtfldUsername.text = [usernamepasswordKVPairs objectForKey:KEY_USERNAME];  
  3. txtfldPassword.text = [usernamepasswordKVPairs objectForKey:KEY_PASSWORD];  

删除一个keychain item:

  1. [CHKeychain delete:KEY_USERNAME_PASSWORD];  

这样一个简单的使用keychain存取用户名密码的功能就做好了。

另外附上一篇写得更详细的e文:http://useyourloaf.com/blog/2010/3/29/simple-iphone-keychain-access.html

相关文章推荐

keychain使用介绍

转载:http://blog.csdn.net/pjk1129/article/details/8239568 iOS的keychain服务提供了一种安全的保存私密信息(密码,序列号,证...

keychain的使用

  • 2016-03-26 10:30
  • 449KB
  • 下载

iOS开发——keychain的使用

通常情况下,我们用NSUserDefaults存储数据信息,但是对于一些私密信息,比如密码、证书等等,就需要使用更为安全的keychain了。keychain里保存的信息不会因App被删除而丢失,在用...

(绝对有用)iOS获取UUID,并使用keychain存储

UDID被弃用,使用UUID来作为设备的唯一标识。获取到UUID后,如果用NSUserDefaults存储,当程序被卸载后重装时,再获得的UUID和之前就不同了。使用keychain存储可以保证程序卸...

iOS开发——keychain的使用

通常情况下,我们用NSUserDefaults存储数据信息,但是对于一些私密信息,比如密码、证书等等,就需要使用更为安全的keychain了。keychain里保存的信息不会因App被删除而丢失,在用...

iOS开发——keychain的使用

iOS开发——keychain的使用 通常情况下,我们用NSUserDefaults存储数据信息,但是对于一些私密信息,比如密码、证书等等,就需要使用更为安全的keychai...

如何使用KeyChain保存和获取UDID

如何使用KeyChain保存和获取UDID     本文是iOS7系列文章第一篇文章,主要介绍使用KeyChain保存和获取APP数据,解决iOS7上获取不变UDID的问题。并给出一个获取...

ios--使用keychain存取密码

通常情况下,我们用NSUserDefaults存储数据信息,但是对于一些私密信息,比如密码、证书等等,就需要使用更为安全的keychain了。keychain里保存的信息不会因App被删除而丢失,在用...

如何使用iOS Keychain存储用户敏感信息

iOS的keychain服务提供了一种安全的保存私密信息(密码,序列号,证书等)的方式,每个ios程序都有一个独立的keychain存储。

如何使用KeyChain保存和获取不变的UDID

转自:http://www.cnblogs.com/smileEvday/p/UDID.html  如何获取不变的UDID  本文是iOS7系列文章第一篇文章,主要介绍使用KeyChain保存和...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)