這篇文章將為大家詳細講解有關(guān)如何在iOS中獲取設(shè)備的唯一標(biāo)示符,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站制作、做網(wǎng)站、外貿(mào)營銷網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)莊河,10多年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792在開發(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è)備的序列號,這個也是目前為止唯一可以確認唯一的標(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é)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。