設備唯一識別IDFA的構建與保證二次安裝唯一性(ios自學筆記)

WWDC 2013已經閉幕,IOS7 Beta隨即發佈,界面之難看無以言表...,簡直就是山寨Android。

更讓IOS程序猿悲催的是,設備唯一標識的MAC Address在IOS7中也失效了。

IOS系統中,獲取設備唯一標識的方法有很多:

一.UDID(Unique Device Identifier)

 UDID的全稱是Unique Device Identifier,顧名思義,它就是蘋果IOS設備的唯一識別碼,它由40個字符的字母和數字組成。

二.UUID(Universally Unique Identifier) 

UUID是Universally Unique Identifier的縮寫,中文意思是通用唯一識別碼.

三.MAC Address

四.OPEN UDID

五.廣告標示符(IDFA-identifierForIdentifier)

六.Vindor標示符 (IDFV-identifierForVendor)

Vendor是CFBundleIdentifier(反轉DNS格式)的前兩部分。來自同一個運營商的應用運行在同一個設備上,此屬性的值是相同的;不同的運營商應用運行在同一個設備上值不同。

經測試,只要設備上有一個tencent的app,重新安裝後的identifierForVendor值不變,如果tencent的app全部刪除,重新安裝後的identifierForVendor值改變。

 

但是很不幸,上面所有這些表示設備唯一號的標識,在IOS7中要麼被禁止使用,要麼重新安裝程序後兩次獲取的標識符不一樣。

由於IOS系統存儲的數據都是在sandBox裏面,一旦刪除App,sandBox也不復存在。好在有一個例外,那就是keychain(鑰匙串)。

通常情況下,IOS系統用NSUserDefaults存儲數據信息,但是對於一些私密信息,比如密碼、證書等等,就需要使用更爲安全的keychain了。

keychain裏保存的信息不會因App被刪除而丟失。所以,可以利用這個keychain這個特點來保存設備唯一標識。

那麼,如何在應用裏使用使用keyChain呢,我們需要導入Security.framework ,keychain的操作接口聲明在頭文件SecItem.h裏。

直接使用SecItem.h裏方法操作keychain,需要寫的代碼較爲複雜,我們可以使用已經封裝好了的工具類KeychainItemWrapper來對keychain進行操作。

KeychainItemWrapper是apple官方例子“GenericKeychain”裏一個訪問keychain常用操作的封裝類,在官網上下載了GenericKeychain項目後,

只需要把“KeychainItemWrapper.h”和“KeychainItemWrapper.m”拷貝到我們項目,並導入Security.framework 。KeychainItemWrapper的用法:

/** 初始化一個保存用戶帳號的KeychainItemWrapper */
KeychainItemWrapper *wrapper = [[KeychainItemWrapper alloc] initWithIdentifier:@"Account Number"
accessGroup:@"YOUR_APP_ID_HERE.com.yourcompany.AppIdentifier"];  
 
//保存數據
[wrapper setObject:@"<帳號>" forKey:(id)kSecAttrAccount];    
 
[wrapper setObject:@"<帳號密碼>" forKey:(id)kSecValueData];    
 
//從keychain裏取出帳號密碼
NSString *password = [wrapper objectForKey:(id)kSecValueData];      
 
//清空設置
[wrapper resetKeychainItem];

其中方法“- (void)setObject:(id)inObject forKey:(id)key;”裏參數“forKey”的值應該是Security.framework 裏頭文件“SecItem.h”裏定義好的key,用其他字符串做key程序會出錯!

發佈了39 篇原創文章 · 獲贊 15 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章