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
    
  • 3.2、使用方法一: 苹果有一个类KeychainItemWrapper可以下载下来使用

    IDFV+KeyChain(设备唯一标识符)_第1张图片
    JKOCKeyChainUUID

    使用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);
    

    在码云上我也放了一份demo:JKOCGitKeyChainUUID

你可能感兴趣的:(IDFV+KeyChain(设备唯一标识符))