[iOS]数据永久保存(KeyChain)
2014-07-10 11:00
274 查看
在开发App的时候,有一些数据是需要保存在App之外的,就是说即使用户删除了App,也要保留的这些数据。
例如(替代UDID,判断是否是第一次安装。。。。。。)
这样的数据就需要保存在系统的钥匙串中。 注意:保存在系统钥匙串中的数据也不是绝对不会被删除的,当用户重新刷机时会被清除掉。越狱后有一些工具可以修改这些数据。
下面提供实现:
LYKeyChain.h 文件:
#import <Foundation/Foundation.h>
@interface LYKeyChain : NSObject
// 保存数据
+ (void)save:(NSString *)key data:(id)data;
// 加载数据
+ (id)load:(NSString *)key;
// 删除数据
+ (void)delete:(NSString *)key;
@end
LYKeyChain.m 文件:
例如(替代UDID,判断是否是第一次安装。。。。。。)
这样的数据就需要保存在系统的钥匙串中。 注意:保存在系统钥匙串中的数据也不是绝对不会被删除的,当用户重新刷机时会被清除掉。越狱后有一些工具可以修改这些数据。
下面提供实现:
LYKeyChain.h 文件:
#import <Foundation/Foundation.h>
@interface LYKeyChain : NSObject
// 保存数据
+ (void)save:(NSString *)key data:(id)data;
// 加载数据
+ (id)load:(NSString *)key;
// 删除数据
+ (void)delete:(NSString *)key;
@end
LYKeyChain.m 文件:
#import "LYKeyChain.h" #import <Security/Security.h> @implementation LYKeyChain // 获取数据 + (NSMutableDictionary *)keychainQuery:(NSString *)key { if (key) { return [NSMutableDictionary dictionaryWithObjectsAndKeys: (__bridge_transfer id)kSecClassGenericPassword, (__bridge_transfer id)kSecClass, key, (__bridge_transfer id)kSecAttrService, key, (__bridge_transfer id)kSecAttrAccount, (__bridge_transfer id)kSecAttrAccessibleAfterFirstUnlock, (__bridge_transfer id)kSecAttrAccessible, nil]; } return nil; } // 保存数据 + (void)save:(NSString *)key data:(id)data { if (key && data != nil) { //Get search dictionary NSMutableDictionary *keychainQuery = [self keychainQuery:key]; //Delete old item before add new item SecItemDelete((__bridge_retained CFDictionaryRef)keychainQuery); //Add new object to search dictionary(Attention:the data format) [keychainQuery setObject:[NSKeyedArchiver archivedDataWithRootObject:data] forKey:(__bridge_transfer id)kSecValueData]; //Add item to keychain with the search dictionary SecItemAdd((__bridge_retained CFDictionaryRef)keychainQuery, NULL); } } // 加载数据 + (id)load:(NSString *)key { id ret = nil; if (key) { NSMutableDictionary *keychainQuery = [self keychainQuery:key]; //Configure the search setting [keychainQuery setObject:(id)kCFBooleanTrue forKey:(__bridge_transfer id)kSecReturnData]; [keychainQuery setObject:(__bridge_transfer id)kSecMatchLimitOne forKey:(__bridge_transfer id)kSecMatchLimit]; CFDataRef keyData = NULL; if (SecItemCopyMatching((__bridge_retained CFDictionaryRef)keychainQuery, (CFTypeRef *)&keyData) == noErr) { @try { ret = [NSKeyedUnarchiver unarchiveObjectWithData:(__bridge_transfer NSData *)keyData]; } @catch (NSException *e) { NSLog(@"Unarchive of %@ failed: %@", key, e); } @finally {} } } return ret; } // 删除数据 + (void)delete:(NSString *)key { NSMutableDictionary *keychainQuery = [self keychainQuery:key]; SecItemDelete((__bridge_retained CFDictionaryRef)keychainQuery); } @end
相关文章推荐
- iOS开发 -- KeyChain使用与共享数据
- iOS应用程序安全(20)-本地数据存储及其安全性(NSUserDefaults, Keychain,CoreData, Sqlite, Plist 文件)
- iOS keychain存储数据
- iOS Keychain钥匙串,应用间数据共享打造iOS上的全家桶
- iOS中永久保存用户数据的两个地方
- iOS 中使用 Keychain Services 在应用间共享数据
- 75.iOS使用KeyChain存储数据与不同App间共享数据
- libGDX引擎之存入数据到keychain(IOS)
- 第四章:iOS应用漏洞利用 ——4.4 Keychain数据存储和安全
- iOS用户数据安全:Keychain、Touch ID以及1Password
- iOS开发--利用keychain保存用户数据
- iOS开发——用keychain来保存更隐秘的数据
- [Cocoa]iOS中永久保存用户数据的两个地方
- iOS用户数据安全:Keychain、Touch ID以及1Password
- iOS 数据持久化之KeyChain(Swift Demo)
- iOS用户数据安全:Keychain、Touch ID以及1Password