您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何在iOS中獲取設備的唯一標示符,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
在開發中會遇到應用需要記錄設備標示,即使應用卸載后再安裝也可重新識別的情況,在這寫一種實現方式——讀取設備的UUID(Universally Unique Identifier)并通過KeyChain記錄。
首先iOS中獲取設備唯一標示符的方法一直隨版本的更新而變化。iOS 2.0版本以后UIDevice提供一個獲取設備唯一標識符的方法uniqueIdentifier,通過該方法我們可以獲取設備的序列號,這個也是目前為止唯一可以確認唯一的標示符。好景不長,因為該唯一標識符與手機一一對應,蘋果覺得可能會泄露用戶隱私,所以在 iOS 5.0之后該方法就被廢棄掉了;iOS 6.0系統新增了兩個用于替換uniqueIdentifier的接口,分別是:identifierForVendor,advertisingIdentifier,但這兩個接口會在應用重新安裝時改變數值,并不是唯一的標示符,所以開發者改為使用WiFi的mac地址來取代;iOS 7中蘋果又封殺mac地址,所以開發者再次改變思路使用KeyChain來保存獲取到的UDID,這樣以后即使APP刪了再裝回來,也可以從KeyChain中讀取回來。
首先保存設備的UUID,可以使用類方法+ (id)UUID 是一個類方法,調用該方法可以獲得一個UUID。通過下面的代碼可以獲得一個UUID字符串:
NSString *uuid = [[NSUUID UUID] UUIDString];
也可以保存在iOS 6中新增的Vindor標示符 (IDFV-identifierForVendor),獲取這個IDFV的新方法被添加在已有的UIDevice類中。跟advertisingIdentifier一樣,該方法返回的是一個NSUUID對象。
NSString *idfv = [[[UIDevice currentDevice] identifierForVendor] UUIDString];
如果用戶卸載了同一個vendor對應的所有程序,然后在重新安裝同一個vendor提供的程序,此時identifierForVendor會被重置,所以這里要用到KeyChain來保存。
KeyChain(鑰匙串)是使用蘋果設備經常使用的,通常要調試的話,都得安裝證書之類的,這些證書就是保存在KeyChain中,還有我們平時瀏覽網頁記錄的賬號密碼也都是記錄在KeyChain中。iOS中的KeyChain相比OS X比較簡單,整個系統只有一個KeyChain,每個程序都可以往KeyChain中記錄數據,而且只能讀取到自己程序記錄在KeyChain中的數據。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
這四個方法參數比較復雜,一旦傳錯就會導致操作KeyChain失敗,文檔中介紹的比較詳細,大家可以查查官方文檔。而蘋果提供的KeyChain使用起來略麻煩,所以這里推薦一個第三方庫SAMKeyChains.SAMKeyChains對蘋果安全框架API進行了簡單封裝,支持對存儲在鑰匙串中密碼、賬戶進行訪問,包括讀取、刪除和設置。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 參數應該是一致的。
更多詳細用法說明可以看SAMKeyChains Documentation
基本的實現思路便是這樣,下面是具體的一種具體實現代碼,僅供參考。
+ (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; }
關于如何在iOS中獲取設備的唯一標示符就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。