溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何在iOS中獲取設(shè)備的唯一標(biāo)示符

發(fā)布時間:2021-02-19 15:58:32 來源:億速云 閱讀:172 作者:Leah 欄目:移動開發(fā)

這篇文章將為大家詳細講解有關(guān)如何在iOS中獲取設(shè)備的唯一標(biāo)示符,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

在開發(fā)中會遇到應(yīng)用需要記錄設(shè)備標(biāo)示,即使應(yīng)用卸載后再安裝也可重新識別的情況,在這寫一種實現(xiàn)方式——讀取設(shè)備的UUID(Universally Unique Identifier)并通過KeyChain記錄。

首先iOS中獲取設(shè)備唯一標(biāo)示符的方法一直隨版本的更新而變化。iOS 2.0版本以后UIDevice提供一個獲取設(shè)備唯一標(biāo)識符的方法uniqueIdentifier,通過該方法我們可以獲取設(shè)備的序列號,這個也是目前為止唯一可以確認(rèn)唯一的標(biāo)示符。好景不長,因為該唯一標(biāo)識符與手機一一對應(yīng),蘋果覺得可能會泄露用戶隱私,所以在 iOS 5.0之后該方法就被廢棄掉了;iOS 6.0系統(tǒng)新增了兩個用于替換uniqueIdentifier的接口,分別是:identifierForVendor,advertisingIdentifier,但這兩個接口會在應(yīng)用重新安裝時改變數(shù)值,并不是唯一的標(biāo)示符,所以開發(fā)者改為使用WiFi的mac地址來取代;iOS 7中蘋果又封殺mac地址,所以開發(fā)者再次改變思路使用KeyChain來保存獲取到的UDID,這樣以后即使APP刪了再裝回來,也可以從KeyChain中讀取回來。

首先保存設(shè)備的UUID,可以使用類方法+ (id)UUID 是一個類方法,調(diào)用該方法可以獲得一個UUID。通過下面的代碼可以獲得一個UUID字符串:

 NSString *uuid = [[NSUUID UUID] UUIDString];

也可以保存在iOS 6中新增的Vindor標(biāo)示符 (IDFV-identifierForVendor),獲取這個IDFV的新方法被添加在已有的UIDevice類中。跟advertisingIdentifier一樣,該方法返回的是一個NSUUID對象。

NSString *idfv = [[[UIDevice currentDevice] identifierForVendor] UUIDString];

如果用戶卸載了同一個vendor對應(yīng)的所有程序,然后在重新安裝同一個vendor提供的程序,此時identifierForVendor會被重置,所以這里要用到KeyChain來保存。

KeyChain(鑰匙串)是使用蘋果設(shè)備經(jīng)常使用的,通常要調(diào)試的話,都得安裝證書之類的,這些證書就是保存在KeyChain中,還有我們平時瀏覽網(wǎng)頁記錄的賬號密碼也都是記錄在KeyChain中。iOS中的KeyChain相比OS X比較簡單,整個系統(tǒng)只有一個KeyChain,每個程序都可以往KeyChain中記錄數(shù)據(jù),而且只能讀取到自己程序記錄在KeyChain中的數(shù)據(jù)。iOS中Security.framework框架提供了四個主要的方法來操作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

這四個方法參數(shù)比較復(fù)雜,一旦傳錯就會導(dǎo)致操作KeyChain失敗,文檔中介紹的比較詳細,大家可以查查官方文檔。而蘋果提供的KeyChain使用起來略麻煩,所以這里推薦一個第三方庫SAMKeyChains.SAMKeyChains對蘋果安全框架API進行了簡單封裝,支持對存儲在鑰匙串中密碼、賬戶進行訪問,包括讀取、刪除和設(shè)置。SAMKeyChains使用簡單,通過實例代碼便可掌握。

//保存一個UUID字符串到鑰匙串:
CFUUIDRef uuid = CFUUIDCreate(NULL);
assert(uuid != NULL);
CFStringRef uuidStr = CFUUIDCreateString(NULL, uuid);
 [SAMKeychain setPassword: [NSString stringWithFormat:@"%@", uuidStr]
 forService:@"com.yourapp.yourcompany"account:@"user"];

//從鑰匙串讀取UUID:
NSString *retrieveuuid = [SAMKeychain passwordForService:@"com.yourapp.yourcompany"account:@"user"];

**注意: setPassword和passwordForSevice方法中的**services 和 accounts 參數(shù)應(yīng)該是一致的。

更多詳細用法說明可以看SAMKeyChains Documentation

基本的實現(xiàn)思路便是這樣,下面是具體的一種具體實現(xiàn)代碼,僅供參考。

+ (NSString *)getDeviceId
{
  NSString * currentDeviceUUIDStr = [SAMKeychain passwordForService:@" "account:@"uuid"];
  if (currentDeviceUUIDStr == nil || [currentDeviceUUIDStr isEqualToString:@""])
  {
    NSUUID * currentDeviceUUID = [UIDevice currentDevice].identifierForVendor;
    currentDeviceUUIDStr = currentDeviceUUID.UUIDString;
    currentDeviceUUIDStr = [currentDeviceUUIDStr stringByReplacingOccurrencesOfString:@"-" withString:@""];
    currentDeviceUUIDStr = [currentDeviceUUIDStr lowercaseString];
    [SAMKeychain setPassword: currentDeviceUUIDStr forService:@" "account:@"uuid"];
  }
  return currentDeviceUUIDStr;
}

關(guān)于如何在iOS中獲取設(shè)備的唯一標(biāo)示符就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

ios
AI