在正式开始前,先介绍iOS保存重要信息的一种方式keychain
iOS的keychain服务提供了一种安全的保存私密信息(密码,序列号,证书等)的方式,每个ios程序都有一个独立的keychain存储。相对于NSUserDefaults、文件保存等一般方式,keychain保存更为安全,而且keychain里保存的信息不会因App被删除而丢失,所以在重装App后,keychain里的数据还能使用。
#pragma mark - 判断唯一标示是否存在,如果不存在就保存一个 每次删除App后UUIDString都会改变 所以需要结合keyChain使用--
+(void)saveIdentifierForVendorIfNotExit{
KeychainItemWrapper *keyChainItem=[[KeychainItemWrapper alloc]initWithIdentifier:@"O2OUserAppHankUUID" accessGroup:nil];
NSString *strUUID = [keyChainItem objectForKey:(__bridge id)kSecAttrAccount];
if(strUUID==nil||[strUUID isEqualToString:@""]){
//对供应商来说是唯一的一个值,也就是说,由同一个公司发行的的app在相同的设备上运行的时候都会有这个相同的标识符。然而,如果用户删除了这个供应商的app然后再重新安装的话,这个标识符就会不一致。
NSString * identifierForVendor = [UIDevice currentDevice].identifierForVendor.UUIDString;
NSString * identifierForVendorString = [identifierForVendor stringByReplacingOccurrencesOfString:@"-" withString:@""];
[keyChainItem setObject:identifierForVendorString forKey:(__bridge id)kSecAttrAccount];
}
}
#pragma mark - 获取唯一标示
+(NSString *)getIdentifierForVendor{
KeychainItemWrapper *keyChainItem=[[KeychainItemWrapper alloc]initWithIdentifier:@"O2OUserAppHankUUID" accessGroup:nil];
NSString *strUUID = [keyChainItem objectForKey:(__bridge id)kSecAttrAccount];
return strUUID;
}