苹果IOS设备的唯一识别码; 现在无法通过代码获取了,证书添加设备号就是这个。
手机连接电脑后,打开Xcode,然后选择window-->Device and Simulator-->Device
选中自己的手机,就能看到信息,"Identifier"这一栏,便是UDID。
点击上面链接,扫描二维码,会提示安装一个描述文件,点击安装之后,就会在浏览器中显示出设备信息。长按复制"设备信息UDID"下面的值,就是UDID了。
广告标示符,适用于对外:例如广告推广,换量等跨应用的用户追踪等。是iOS6中另外一个新的方法,提供了一个方法advertisingIdentifier,通过调用该方法会返回一个NSUUID实例,最后可以获得一个UUID,由系统存储着的。不过即使这是由系统存储的,但是有几种情况下,会重新生成广告标示符。
如果用户完全重置系统((设置程序-> 通用 -> 还原 -> 还原位置与隐私) ,这个广告标示符会重新生成。
如果用户明确的还原广告(设置程序->通用 -> 关于本机 -> 广告 -> 还原广告标示符),那么广告标示符也会重新生成。关于广告标示符的还原,有一点需要注意:如果程序在后台运行,此时用户“还原广告标示符”,然后再回到程序中,此时获取广告标示符并不会立即获得还原后的标示符。必须要终止程序,然后再重新启动程序,才能获得还原后的广告标示符。
在iOS 10.0以后如果用户打开限制广告跟踪(设置程序-> 通用 -> 关于本机 -> 广告 -> 限制广告跟踪),则获取到的IDFA为一个固定值00000000-0000-0000-0000-000000000000。因此,通过IDFA也无法唯一标识一个设备。
在同一个设备上的所有App都会取到相同的值,是苹果专门给各广告提供商用来追踪用户而设的,用户可以在 设置|隐私|广告追踪 里重置此id的值,或限制此id的使用,故此id有可能会取不到值,但好在Apple默认是允许追踪的,而且一般用户都不知道有这么个设置,所以基本上用来监测推广效果,是戳戳有余了。
NSString *IDFA = [[[ASIdentifierManager sharedManager] advertisingIdentifier] UUIDString];
注意:由于idfa会出现取不到的情况,故绝不可以作为业务分析的主id,来识别用户。
供应商标识符,适用于对内:例如分析用户在应用内的行为等。
IDFV是给供应商标识用户用的,每个设备在所属同一个供应商的应用里,都有相同的值。准确的说,是通过BundleID的反转的前两部分进行匹配,如果相同就是同一个供应商,例如对于com.abc.app1, com.abc.app2 这两个BundleID来说,就属于同一个供应商,共享同一个IDFV的值。当然,对于同一个设备不同供应商的话,获取到的值是不同的。和IDFA不同的是,IDFV的值是一定能取到的
。它是iOS 6中新增的,获取方法如下:
NSString *IDFV = [[[UIDevice currentDevice] identifierForVendor] UUIDString];
但是使用IDFV也会存在一些问题。只要此应用 (或属于同一供应商的另一款应用) 还安装在 iOS 设备上,该属性值就不会发生变化。如果用户将设备上属于该供应商的所有应用删除,然后重装该供应商的一款或多款应用,该值就会发生变化。
UUID是Universally Unique Identifier的缩写,中文意思是通用唯一识别码。它是苹果提供的一个获取大随机数的方法,据说UUID随机数算法得到的数重复概率为170亿分之一。这样,每个人都可以建立不与其它人冲突的 UUID。
NSUUID在iOS 6.0中才出现,这跟CFUUID几乎完全一样,只不过它是Objective-C接口。通过下面的代码可以获得一个UUID字符串:
NSString *uuid = [[NSUUID UUID] UUIDString];
苹果公司建议使用UUID为应用生成唯一标识字符串
。但是获得的UUID值系统没有存储, 而且每次调用得到UUID,系统都会返回一个新的唯一标示符。如果你希望存储这个标示符,可以将其存储到 Keychain 中。
Keychain是OS X和iOS都提供的一种安全存储敏感信息工具:可以在Keychain中存储用户名、密码等信息;iOS16新增 LARightStore 用于存储与获取 keychain 中的数据。
Keychain的安全机制从系统层面保证了存储的敏感信息不会被非法读取或者窃取。
每个程序都可以往KeyChain中记录数据,而且只能读取到自己程序记录在KeyChain中的数据。
Keychain的特点如下:
保存在Keychain中的数据,即使应用程序被卸载,数据仍然存在;重新安装应用程序,我们也可以从Keychain中读取这些数据。
Keychain中的数据可以通过Group的方式实现应用程序之间共享,只要应用程序具有相同的TeamID即可。
保存在Keychain中的数据都是经过加密的,因此非常安全。
系统还原、刷机、iPhone系统升级导致存储路径变化 会导致 KeyChain 中的数据丢失。
因此开发者可以在应用第一次启动时调用一次生成 UUID,通过 KeyChain 钥匙串保存在iOS系统里面,如果应用删除了,重装应用之后它的UUID还是一样的,除非系统重置。
IDFA、IDFV、UUID都是32位
[1]
Get the UDID: https://www.pgyer.com/tools/udid