iOS獲取設(shè)備唯一標(biāo)識(shí)的8種方法

8種iOS獲取設(shè)備唯一標(biāo)識(shí)的方法脆荷,希望對(duì)大家有用蚌成。

UDID

UDID(Unique Device Identifier)芭析,iOS 設(shè)備的唯一識(shí)別碼截珍,是一個(gè)40位十六進(jìn)制序列(越獄的設(shè)備通過(guò)某些工具可以改變?cè)O(shè)備的 UDID)攀甚,移動(dòng)網(wǎng)絡(luò)可以利用 UDID 來(lái)識(shí)別移動(dòng)設(shè)備啄糙。

許多開發(fā)者把 UDID 跟用戶的真實(shí)姓名、密碼云稚、住址隧饼、其它數(shù)據(jù)關(guān)聯(lián)起來(lái),網(wǎng)絡(luò)窺探者會(huì)從多個(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)地址捏浊,用來(lái)表示互聯(lián)網(wǎng)上每一個(gè)站點(diǎn)的標(biāo)示符,是一個(gè)六個(gè)字節(jié)(48位)的十六進(jìn)制序列撞叨。前三個(gè)字節(jié)是由 IEEE 的注冊(cè)管理機(jī)構(gòu) RA 負(fù)責(zé)給不同廠家分配的”編制上唯一的標(biāo)示符(Organizationally Unique Identifier)”金踪,后三個(gè)字節(jié)由各廠家自行指派給生產(chǎn)的適配器接口,稱為擴(kuò)展標(biāo)示符牵敷。

MAC 地址在網(wǎng)絡(luò)上用來(lái)區(qū)分設(shè)備的唯一性胡岔,接入網(wǎng)絡(luò)的設(shè)備都有一個(gè)MAC地址,他們肯定都是唯一的枷餐。一部 iPhone 上可能有多個(gè) MAC 地址靶瘸,包括 WIFI 的、SIM 的等毛肋,但是 iTouch 和 iPad 上就有一個(gè) WIFI 的怨咪,因此只需獲取 WIFI 的 MAC 地址就好了。一般會(huì)采取 MD5(MAC 地址 + bundleID)獲取唯一標(biāo)識(shí)润匙。

但是 MAC 地址和 UDID 一樣诗眨,存在隱私問題, iOS 7 之后趁桃,所有設(shè)備請(qǐng)求 MAC 地址會(huì)返回一個(gè)固定值辽话,這個(gè)方法也不攻自破了。

OpenUDID

UDID 被棄用后卫病,廣大開發(fā)者需要尋找一個(gè)可以替代的 UDID油啤,并且不受蘋果控制的方案,由此蟀苛,OpenUDID 成為了當(dāng)時(shí)使用最廣泛的開源 UDID 代替方案益咬。OpenUDID 利用一個(gè)非常巧妙的方法在不同程序間存儲(chǔ)標(biāo)示符:在粘貼板中用了一個(gè)特殊的名稱來(lái)存儲(chǔ)標(biāo)示符,通過(guò)這種方法帜平,其他應(yīng)用程序也可以獲取幽告。

蘋果在 iOS 7 之后對(duì)粘貼板做了限制梅鹦,導(dǎo)致同一個(gè)設(shè)備上的應(yīng)用間,無(wú)法再共享一個(gè) OpenUDID冗锁。

UUID + 自己存儲(chǔ)

UUID(Universally Unique IDentifier)齐唆,通用唯一標(biāo)示符,是一個(gè)32位的十六進(jìn)制序列冻河,使用小橫線來(lái)連接:8-4-4-4-12箍邮,通過(guò) NSUUID(iOS 6 之后)[NSUUID UUID].UUIDString 或者 CFUUID(iOS 2 之后) CFBridgingRelease(CFUUIDCreateString(kCFAllocatorDefault, CFUUIDCreate(kCFAllocatorDefault))) 來(lái)獲取,但是每次獲取的值都不一樣叨叙,需要自己存儲(chǔ)锭弊。

推送 token + bundleID

推送 token 保證設(shè)備唯一,但是必須有網(wǎng)絡(luò)情況下才能工作擂错,該方法不依賴于設(shè)備本身味滞,但依賴于 apple push,而 apple push 有時(shí)候會(huì)抽風(fēng)的钮呀。

IDFA

IDFA-identifierForIdentifier(廣告標(biāo)示符)剑鞍,在同一個(gè)設(shè)備上的所有 APP 都會(huì)取到相同的值,是蘋果專門給各廣告提供商用來(lái)追蹤用戶而設(shè)定的行楞。雖然 iPhone 默認(rèn)是允許追蹤的攒暇,而且一般用戶都不知道有這么個(gè)設(shè)置,但是用戶可以在 設(shè)置 - 隱私 - 廣告追蹤 里重置此 ID 的值子房,或者限制此 ID 的使用,所以有可能會(huì)取不到值就轧。

IDFV

IDFV-identifierForVendor(Vendor 標(biāo)示符)证杭,通過(guò) [UIDevice currentDevice].identifierForVendor.UUIDString 來(lái)獲取。是通過(guò) bundleID 的反轉(zhuǎn)的前兩部分進(jìn)行匹配妒御,如果相同是同一個(gè) Vendor 解愤,例如對(duì)于 com.mayan.app_1 和 com.mayan.app_2 這兩個(gè) bundleID 來(lái)說(shuō),就屬于同一個(gè) Vendor 乎莉,共享同一個(gè) IDFV送讲,和 IDFA 不同的是,IDFV 的值一定能取到的惋啃,所以非常適合于作為內(nèi)部用戶行為分析的主 ID 來(lái)識(shí)別用戶哼鬓。但是用戶刪除了該 APP ,則 IDFV 值會(huì)被重置边灭,再次安裝此 APP 异希,IDFV 的值和之前的不同。

IDFV + keychain

通過(guò)以上幾種儲(chǔ)存唯一標(biāo)識(shí)的方法的分析绒瘦,總結(jié)一下各有優(yōu)劣称簿。很多方法被蘋果禁止或者漏洞太多扣癣,越來(lái)越不被開發(fā)者使用,現(xiàn)在蘋果主推 IDFA 和 IDFV 這兩種方法憨降,分別對(duì)外和對(duì)內(nèi)父虑,但是 IDFV 在 APP 重新安裝時(shí)會(huì)更改,所以我的方法是通過(guò)第一次生成的 IDFV 存儲(chǔ)到 keychain 中授药,以后每次獲取標(biāo)識(shí)符都從 keychain 中獲取频轿。

#import

@interface MYVendorToll : NSObject

+ (NSString *)getIDFV;

@end

#import "MYVendorToll.h"

#import "MYKeyChainTool.h"

@implementation MYVendorToll

+ (NSString *)getIDFV

{

?NSString *IDFV = (NSString *)[MYKeyChainTool load:@"IDFV"];


?if([IDFV isEqualToString:@""] || !IDFV) {


??IDFV = [UIDevice currentDevice].identifierForVendor.UUIDString;

??[MYKeyChainTool save:@"IDFV"data:IDFV];

?}


?returnIDFV;

}


@end

#import

@interface MYKeyChainTool : NSObject

+ (void)save:(NSString *)service data:(id)data;

+ (id)load:(NSString *)service;

+ (void)deleteKeyData:(NSString *)service;

@end

#import "MYKeyChainTool.h"

@implementation MYKeyChainTool

+ (NSMutableDictionary *)getKeychainQuery:(NSString *)service {

?return[NSMutableDictionary dictionaryWithObjectsAndKeys:

???(id)kSecClassGenericPassword,(id)kSecClass,

???service, (id)kSecAttrService,

???service, (id)kSecAttrAccount,

???(id)kSecAttrAccessibleAfterFirstUnlock,(id)kSecAttrAccessible,

???nil];

}

+ (void)save:(NSString *)service data:(id)data {

?//Get search dictionary

?NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];

?//Delete old item before add new item

?SecItemDelete((CFDictionaryRef)keychainQuery);

?//Add new object to search dictionary(Attention:the data format)

?[keychainQuery setObject:[NSKeyedArchiver archivedDataWithRootObject:data] forKey:(id)kSecValueData];

?//Add item to keychain with the search dictionary

?SecItemAdd((CFDictionaryRef)keychainQuery, NULL);

}

+ (id)load:(NSString *)service {

?id ret = nil;

?NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];

?//Configure the search setting

?//Since in our simple case we are expecting only a single attribute to be returned (the password) we can set the attribute kSecReturnData to kCFBooleanTrue

?[keychainQuery setObject:(id)kCFBooleanTrue forKey:(id)kSecReturnData];

?[keychainQuery setObject:(id)kSecMatchLimitOne forKey:(id)kSecMatchLimit];

?CFDataRef keyData = NULL;

?if(SecItemCopyMatching((CFDictionaryRef)keychainQuery, (CFTypeRef *)&keyData) == noErr) {

??@try{

???ret = [NSKeyedUnarchiver unarchiveObjectWithData:(__bridge NSData *)keyData];

??} @catch(NSException *e) {

???NSLog(@"Unarchive of %@ failed: %@", service, e);

??} @finally {

??}

?}

?if(keyData)

??CFRelease(keyData);

?returnret;

}

+ (void)deleteKeyData:(NSString *)service {

?NSMutableDictionary *keychainQuery = [self getKeychainQuery:service];

?SecItemDelete((CFDictionaryRef)keychainQuery);

}

@end

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市烁焙,隨后出現(xiàn)的幾起案子航邢,更是在濱河造成了極大的恐慌,老刑警劉巖骄蝇,帶你破解...
    沈念sama閱讀 212,383評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件膳殷,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡九火,警方通過(guò)查閱死者的電腦和手機(jī)赚窃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)岔激,“玉大人勒极,你說(shuō)我怎么就攤上這事÷嵌Γ” “怎么了辱匿?”我有些...
    開封第一講書人閱讀 157,852評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)炫彩。 經(jīng)常有香客問我匾七,道長(zhǎng),這世上最難降的妖魔是什么江兢? 我笑而不...
    開封第一講書人閱讀 56,621評(píng)論 1 284
  • 正文 為了忘掉前任昨忆,我火速辦了婚禮,結(jié)果婚禮上杉允,老公的妹妹穿的比我還像新娘邑贴。我一直安慰自己,他們只是感情好叔磷,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,741評(píng)論 6 386
  • 文/花漫 我一把揭開白布拢驾。 她就那樣靜靜地躺著,像睡著了一般世澜。 火紅的嫁衣襯著肌膚如雪独旷。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,929評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音嵌洼,去河邊找鬼案疲。 笑死,一個(gè)胖子當(dāng)著我的面吹牛麻养,可吹牛的內(nèi)容都是我干的褐啡。 我是一名探鬼主播,決...
    沈念sama閱讀 39,076評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼鳖昌,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼备畦!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起许昨,我...
    開封第一講書人閱讀 37,803評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤懂盐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后糕档,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體莉恼,經(jīng)...
    沈念sama閱讀 44,265評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,582評(píng)論 2 327
  • 正文 我和宋清朗相戀三年速那,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了俐银。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,716評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡端仰,死狀恐怖捶惜,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情荔烧,我是刑警寧澤吱七,帶...
    沈念sama閱讀 34,395評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站茴晋,受9級(jí)特大地震影響陪捷,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜诺擅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,039評(píng)論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望啡直。 院中可真熱鬧烁涌,春花似錦、人聲如沸酒觅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)舷丹。三九已至抒钱,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谋币。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工仗扬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蕾额。 一個(gè)月前我還...
    沈念sama閱讀 46,488評(píng)論 2 361
  • 正文 我出身青樓早芭,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親诅蝶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子退个,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,612評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容