IDFV+KeyChain(设备唯一标识符)

简介: IDFV+KeyChain(设备唯一标识符)

一、简单的介绍下IDFV(identifierForVendor)


Vindor标示符,适用于对内:例如分析用户在应用内的行为等。是给Vendor标识用户用的,每个设备在所属同一个Vender的应用里,都有相同的值。其中的Vender是指应用提供商(app所属的公司),但准确点说,是通过BundleIDDNS反转的前两部分进行匹配,如果相同就是同一个Vender,例如对于com.somecompany.apponecom.somecompany.apptwo,这两个BundleID来说,就属于同一个Vender,共享同一个IDFV的值。idfv的值是一定能取到的,所以非常适合于作为内部用户行为分析的主id,来标识用户,替代OpenUDID


注意:如果用户将属于此Vender的所有App卸载,则IDFV的值会被重置,即再重装此VenderAppIDFV的值和之前不同


二、对IDFV数据变化的实践测试


  • 1.获取IDFV


NSString * idfv = [[[UIDevice currentDevice] identifierForVendor] UUIDString];
  • 2.在开发者账号里面没有套装IDBundle identifier 工程里面测试


//保存上一次的IDFV
 NSString *oldIDFV = @"EA3D58A145B84F249C454A5A02E3BABD";
 NSString *idfv = [[[UIDevice currentDevice] identifierForVendor] UUIDString];
 idfv = [idfv stringByReplacingOccurrencesOfString:@"-" withString:@""];
 NSLog(@"用户的IDFV=%@ 长度=%ld",idfv,idfv.length);
 if ([oldIDFV isEqualToString:idfv]) {
       NSLog(@"没有发生变化");
 }else{
       NSLog(@"有发生变化");
 }


  • 测试结果:同一个手机在没上线的不同工程里IDFV是一样的,不管app被卸载多少次,IDFV是不变的。但是在上线的app工程里IDFV是只要app卸载了再安装IDFV就会发生变化。


  • 3.在开发者账号里面有套装IDBundle identifier 工程里面测试(在此提供一个:com.yibangbao.Ybangbao)
    还是用上面的代码来测试,只是把Bundle identifier换成了有有套装IDBundle identifier


测试结果:只要app不卸载 IDFV是不会变化的,只要卸载了再安装 IDFV就会发生变化


三、对IDFV进行KeyChain存储在手机里


  • 3.1、如果用户卸载了同一个vendor对应的所有程序,然后在重新安装同一个vendor提供的程序,此时identifierForVendor会被重置,所以这里要用到KeyChain来保存。
    KeyChain(钥匙串)是使用苹果设备经常使用的,通常要调试的话,都得安装证书之类的,这些证书就是保存在KeyChain中,还有我们平时浏览网页记录的账号密码也都是记录在KeyChain中。iOS中的KeyChain相比OS X比较简单,整个系统只有一个KeyChain,每个程序都可以往KeyChain中记录数据,而且只能读取到自己程序记录在KeyChain中的数据。iOS中Security.framework框架提供了四个主要的方法来操作KeyChain:
    这四个方法参数比较复杂,一旦传错就会导致操作KeyChain失败,文档中介绍的比较详细,大家可以查查官方文档


SecItemCopyMatching(CFDictionaryRef query, CFTypeRef *result);//查询OSStatus
SecItemAdd(CFDictionaryRef attributes, CFTypeRef *result); //添加OSStatus
SecItemUpdate(CFDictionaryRef query, CFDictionaryRef attributesToUpdate);//更新KeyChain中的ItemOSStatus
SecItemDelete(CFDictionaryRef query)//删除KeyChain中的ItemOSStatus



image.png

  • 使用KeychainItemWrapper的一个小demoJKOCKeyChainUUID你可以下载下来使用
  • 使用的代码


JKKeyChainUUID *keychain = [[JKKeyChainUUID alloc] init];
NSString *keychainValue = [keychain readUDID];
NSLog(@"keychainValue = %@",keychainValue);
  • 其中 JKKeyChainUUID中的两个宏你可以按照自己意思去改


// 取出唯一标识符的键
#define KEY_IN_KEYCHAIN     @"JKkeychain"
// kSecClass  是你存数据是什么格式,这里是通用密码格式
#define JKKSecClass     @"JKkeychainApp"
  • 3.3、使用方法二:方法而就比较简单了,运用github上面用的比较多的一个三方SAMKeychain,使用量还是比较大的。用CocoaPods导入后,导入头文件#import "SAMKeychain.h"
    为了使用更方便,我写了个类JKKeyChainUUID方便更好的使用,使用方法如下


NSString *keyChain = [JKKeyChainUUID jkGetDeviceId];
NSLog(@"keyChain=%@",keyChain);


目录
相关文章
|
5G 数据安全/隐私保护
5G终端标识SUPI,SUCI及IMSI解析
IMSI,SUPI,SUCI均为UE终端标识,区别在于IMSI为LTE终端标识,SUPI为5G非加密终端标识,一般等同于IMSI,SUCI为5G加密终端标识,需要解密后才能得到SUPI。
2686 0
5G终端标识SUPI,SUCI及IMSI解析
|
监控 安全 JavaScript
浅谈移动端设备标识码:DeviceID、IMEI、IDFA、UDID和UUID
场景 : 客户提出一个问题就是把用户的登录记录和设备绑定到一起,就是每个人都是固定的设备(可能是安全因素吧)。一开始想的是回去设备的IMEI号和用户账号绑定起来,结果发现IMEI不对外开发,只能另寻他法,最后通过获取设备序列号作为唯一标识。
浅谈移动端设备标识码:DeviceID、IMEI、IDFA、UDID和UUID
|
3月前
|
安全 开发者 iOS开发
如何获取安全获取苹果udid,imei
【8月更文挑战第12天】在iOS系统中,苹果出于隐私考量已禁止开发者直接获取设备UDID与IMEI。替代方案包括:1) **供应商标识符** (`[UIDevice currentDevice].identifierForVendor`),适用于同一开发者账号下的应用,可能随应用卸载重装而变化;2) **广告标识符** (`[ASIdentifierManager sharedManager].advertisingIdentifier`),用于广告追踪,用户可选择重置或限制。处理这些标识符时务必遵守苹果隐私政策。
|
存储 安全 iOS开发
iOS开发 - 继udid,Mac地址等一系列唯一标识无效后,如何用KeyChain来实现设备唯一性
iOS开发 - 继udid,Mac地址等一系列唯一标识无效后,如何用KeyChain来实现设备唯一性
473 0
iOS开发 - 继udid,Mac地址等一系列唯一标识无效后,如何用KeyChain来实现设备唯一性
|
存储 Web App开发 JSON
iOS小技能:设备ID除了使用_idfa、_idfv 还可使用其他替代方案(Keychain 存储)
设备信息的获取:除了使用_idfa、_idfv, 还使用sysct 获取cpu信息。
390 0
iOS小技能:设备ID除了使用_idfa、_idfv 还可使用其他替代方案(Keychain 存储)
|
存储 安全 JavaScript
iOS ASO 数据清理(Accounts帐号信息、Keychain数据)
iOS ASO 数据清理(Accounts帐号信息、Keychain数据)
1018 0
iOS ASO 数据清理(Accounts帐号信息、Keychain数据)
|
存储 数据安全/隐私保护 iOS开发
iOS SSKeyChain(钥匙串)--密码存储
保存密码使用到的框架SSKeyChain 登录成功后把账号和密码记录到沙盒中(偏好设置) // 登录成功之后,把账号和密码保存到沙盒中(偏好设置) - (void)saveUserInfo { NSUserDefaults *userDef...
1279 0