国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

iOS 獲取設備唯一標示符的方法詳解

2020-07-26 02:43:03
字體:
來源:轉載
供稿:網友

在開發中會遇到應用需要記錄設備標示,即使應用卸載后再安裝也可重新識別的情況,在這寫一種實現方式――讀取設備的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;}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。、

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 荥经县| 佳木斯市| 淅川县| 浏阳市| 迭部县| 渑池县| 宁乡县| 吉安市| 巴中市| 绥芬河市| 包头市| 西丰县| 阿拉善盟| 建昌县| 清水河县| 林芝县| 汕头市| 石嘴山市| 沁阳市| 连州市| 衡东县| 双鸭山市| 塘沽区| 杭州市| 安康市| 阿克苏市| 浑源县| 吴桥县| 蓝山县| 潞西市| 阿巴嘎旗| 嵊州市| 庆元县| 凌源市| 顺平县| 鄂尔多斯市| 荥阳市| 柯坪县| 诏安县| 琼海市| 朝阳区|