8種iOS獲取設(shè)備唯一標(biāo)識的方法腕扶,希望對大家有用。
UDID
UDID(Unique Device Identifier)粉楚,iOS 設(shè)備的唯一識別碼亿汞,是一個(gè)40位十六進(jìn)制序列(越獄的設(shè)備通過某些工具可以改變設(shè)備的 UDID),移動網(wǎng)絡(luò)可以利用 UDID 來識別移動設(shè)備杆兵。
許多開發(fā)者把 UDID 跟用戶的真實(shí)姓名雁仲、密碼、住址琐脏、其它數(shù)據(jù)關(guān)聯(lián)起來攒砖,網(wǎng)絡(luò)窺探者會從多個(gè)應(yīng)用收集這些數(shù)據(jù),然后順藤摸瓜得到這個(gè)人的許多隱私數(shù)據(jù)日裙,同時(shí)大部分應(yīng)用確實(shí)在頻繁傳輸 UDID 和私人信息吹艇。 為了避免集體訴訟,蘋果最終決定在 iOS 5 的時(shí)候昂拂,將這一慣例廢除受神。
現(xiàn)在應(yīng)用試圖獲取 UDID 已被禁止且不允許上架。
MAC 地址
MAC(Medium / Media Access Control)地址格侯,用來表示互聯(lián)網(wǎng)上每一個(gè)站點(diǎn)的標(biāo)示符鼻听,是一個(gè)六個(gè)字節(jié)(48位)的十六進(jìn)制序列。前三個(gè)字節(jié)是由 IEEE 的注冊管理機(jī)構(gòu) RA 負(fù)責(zé)給不同廠家分配的”編制上唯一的標(biāo)示符(Organizationally Unique Identifier)”联四,后三個(gè)字節(jié)由各廠家自行指派給生產(chǎn)的適配器接口撑碴,稱為擴(kuò)展標(biāo)示符。
MAC 地址在網(wǎng)絡(luò)上用來區(qū)分設(shè)備的唯一性朝墩,接入網(wǎng)絡(luò)的設(shè)備都有一個(gè)MAC地址醉拓,他們肯定都是唯一的。一部 iPhone 上可能有多個(gè) MAC 地址收苏,包括 WIFI 的亿卤、SIM 的等,但是 iTouch 和 iPad 上就有一個(gè) WIFI 的鹿霸,因此只需獲取 WIFI 的 MAC 地址就好了怠噪。一般會采取 MD5(MAC 地址 + bundleID)獲取唯一標(biāo)識。
但是 MAC 地址和 UDID 一樣杜跷,存在隱私問題傍念, iOS 7 之后,所有設(shè)備請求 MAC 地址會返回一個(gè)固定值葛闷,這個(gè)方法也不攻自破了憋槐。
OpenUDID
UDID 被棄用后,廣大開發(fā)者需要尋找一個(gè)可以替代的 UDID淑趾,并且不受蘋果控制的方案阳仔,由此,OpenUDID 成為了當(dāng)時(shí)使用最廣泛的開源 UDID 代替方案。OpenUDID 利用一個(gè)非常巧妙的方法在不同程序間存儲標(biāo)示符:在粘貼板中用了一個(gè)特殊的名稱來存儲標(biāo)示符近范,通過這種方法嘶摊,其他應(yīng)用程序也可以獲取。
蘋果在 iOS 7 之后對粘貼板做了限制评矩,導(dǎo)致同一個(gè)設(shè)備上的應(yīng)用間叶堆,無法再共享一個(gè) OpenUDID。
UUID + 自己存儲
UUID(Universally Unique IDentifier)斥杜,通用唯一標(biāo)示符虱颗,是一個(gè)32位的十六進(jìn)制序列,使用小橫線來連接:8-4-4-4-12蔗喂,通過 NSUUID(iOS 6 之后)[NSUUID UUID].UUIDString 或者 CFUUID(iOS 2 之后) CFBridgingRelease(CFUUIDCreateString(kCFAllocatorDefault, CFUUIDCreate(kCFAllocatorDefault))) 來獲取忘渔,但是每次獲取的值都不一樣,需要自己存儲缰儿。
推送 token + bundleID
推送 token 保證設(shè)備唯一畦粮,但是必須有網(wǎng)絡(luò)情況下才能工作,該方法不依賴于設(shè)備本身乖阵,但依賴于 apple push锈玉,而 apple push 有時(shí)候會抽風(fēng)的。
IDFA
IDFA-identifierForIdentifier(廣告標(biāo)示符)义起,在同一個(gè)設(shè)備上的所有 APP 都會取到相同的值,是蘋果專門給各廣告提供商用來追蹤用戶而設(shè)定的师崎。雖然 iPhone 默認(rèn)是允許追蹤的默终,而且一般用戶都不知道有這么個(gè)設(shè)置,但是用戶可以在 設(shè)置 - 隱私 - 廣告追蹤 里重置此 ID 的值犁罩,或者限制此 ID 的使用齐蔽,所以有可能會取不到值。
IDFV
IDFV-identifierForVendor(Vendor 標(biāo)示符)床估,通過 [UIDevice currentDevice].identifierForVendor.UUIDString 來獲取含滴。是通過 bundleID 的反轉(zhuǎn)的前兩部分進(jìn)行匹配,如果相同是同一個(gè) Vendor 丐巫,例如對于 com.mayan.app_1 和 com.mayan.app_2 這兩個(gè) bundleID 來說谈况,就屬于同一個(gè) Vendor ,共享同一個(gè) IDFV递胧,和 IDFA 不同的是碑韵,IDFV 的值一定能取到的,所以非常適合于作為內(nèi)部用戶行為分析的主 ID 來識別用戶缎脾。但是用戶刪除了該 APP 祝闻,則 IDFV 值會被重置,再次安裝此 APP 遗菠,IDFV 的值和之前的不同联喘。
IDFV + keychain
通過以上幾種儲存唯一標(biāo)識的方法的分析华蜒,總結(jié)一下各有優(yōu)劣。很多方法被蘋果禁止或者漏洞太多豁遭,越來越不被開發(fā)者使用叭喜,現(xiàn)在蘋果主推 IDFA 和 IDFV 這兩種方法,分別對外和對內(nèi)堤框,但是 IDFV 在 APP 重新安裝時(shí)會更改域滥,所以我的方法是通過第一次生成的 IDFV 存儲到 keychain 中,以后每次獲取標(biāo)識符都從?keychain 中獲取