IOS7如何獲取設備惟一標識

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

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

IOS系統中,獲取設備惟一標識的方法有不少:ide

一.UDID(Unique Device Identifier)工具

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

二.UUID(Universally Unique Identifier) spa

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

三.MAC Address字符串

四.OPEN UDIDit

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

六.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程序會出錯!

相關文章
相關標籤/搜索