最近的一個(gè)項(xiàng)目嘹朗,遇到了應(yīng)用之間數(shù)據(jù)共享和設(shè)備唯一標(biāo)識(shí)的問(wèn)題。經(jīng)過(guò)多方面的搜索诲侮、驗(yàn)證镀虐,得到了一些結(jié)論。現(xiàn)在總結(jié)如下:
一沟绪、應(yīng)用之間共享數(shù)據(jù)
1刮便、URL Scheme
在Info.plist中配置URL Types,通過(guò)自定義的協(xié)議绽慈,來(lái)傳遞數(shù)據(jù)恨旱。特性是APP之間通過(guò)協(xié)議傳遞數(shù)據(jù)辈毯,會(huì)有一個(gè)跳轉(zhuǎn)過(guò)程。示例支付寶搜贤、微信支付等谆沃。
2、UIActivityViewController
iOS 6.0以后仪芒,蘋果推出的分享視圖控制器唁影。特性是彈出系統(tǒng)分享控制器,一般用于分享掂名。
3据沈、Shared Keychain
使用Keychain共享數(shù)據(jù),需要開啟Keychain Sharing服務(wù)铆隘,并限于同一供應(yīng)商(即同一個(gè)蘋果證書)下的應(yīng)用之間共享數(shù)據(jù)卓舵。
4、App Groups
iOS 8.0以后膀钠,蘋果推出了App Groups掏湾,使用NSUserDefaults、NSFileManager肿嘲、NSFileCoordination共享數(shù)據(jù)融击,限于同一Group下的應(yīng)用。
5雳窟、UIPasteboard
剪貼板尊浪,是應(yīng)用之間共享文本的一種方式。示例在一個(gè)APP中封救,復(fù)制一段文本拇涤,在另一個(gè)APP中粘貼使用。能跨應(yīng)用分享數(shù)據(jù)了誉结,但是限于數(shù)據(jù)類型鹅士、數(shù)據(jù)量大小,升級(jí)系統(tǒng)數(shù)據(jù)丟失惩坑。
二掉盅、設(shè)備唯一標(biāo)識(shí)
1、UDID
唉以舒,這個(gè)iOS 5.0以后被蘋果禁用了趾痘。
2、UUID
UDID被禁用以后蔓钟,蘋果推出的替代品永票。但是這個(gè)值,同一應(yīng)用、不同時(shí)間調(diào)用時(shí)瓦侮,生成的值不一樣艰赞;不同應(yīng)用,生成的值也不一樣肚吏。唯一的優(yōu)點(diǎn)方妖,每次生成的都是唯一值。
3罚攀、MAC
唉党觅,這個(gè)iOS 7.0以后也被封殺了。
4斋泄、IDFA
全名advertisingIdentifier杯瞻。適用于iOS 6.0以后,在同一臺(tái)設(shè)備上炫掐,所有App都會(huì)取到相同的值魁莉,是蘋果專門給各廣告提供商用來(lái)追蹤用戶而設(shè)的,用戶可以在 設(shè)置|隱私|廣告追蹤 里重置此id的值募胃,或限制此id的使用旗唁,故此id有可能會(huì)取不到值,而且提交蘋果審核時(shí)痹束,必須明確指出使用了該值检疫。
5、IDFV
全名identifierForVendor祷嘶。使用于iOS 6.0以后屎媳,在同一設(shè)備上,同一供應(yīng)商的APP取到相同的值论巍,如果該供應(yīng)商下的所有APP都被刪除烛谊,該值會(huì)被重置。
6嘉汰、OPEN
網(wǎng)上有很多OPENUDID晒来、OPENIDFA。實(shí)現(xiàn)方式為獲取手機(jī)的型號(hào)郑现、系統(tǒng)創(chuàng)建時(shí)間、系統(tǒng)磁盤大小等一些系統(tǒng)屬性組合在一起荧降,使用MD5模擬生成的類似UDID和IDFA的一串字符串接箫。喲,這個(gè)貌似不錯(cuò)朵诫,可以不同的應(yīng)用直接能獲得同一值辛友。但是,如果同一型號(hào)、同一批次出產(chǎn)的手機(jī)废累,那這個(gè)值不就一個(gè)樣了5嗣贰!
好了邑滨,上面介紹了iOS 應(yīng)用共享日缨、設(shè)備唯一符。現(xiàn)在有一需求:實(shí)現(xiàn)不同應(yīng)用之間(跨供應(yīng)商掖看,即不同開發(fā)者賬號(hào))共享登錄賬號(hào)密碼匣距,并能對(duì)用戶是否更換設(shè)備進(jìn)行跟蹤。這個(gè)該怎么實(shí)現(xiàn)鞍タ恰R愦!归榕!
輾轉(zhuǎn)反側(cè)尸红,夜夜不能寐。想到以下條件:
1刹泄、使用UUID生成設(shè)備唯一標(biāo)識(shí)(這個(gè)應(yīng)該不會(huì)被蘋果禁用)外里;
2、使用NSUserDefaults存儲(chǔ)UUID(我們不能每次都去獲取UUID啊循签,不然那還有啥意思)级乐;
3、使用UIPasteboard實(shí)現(xiàn)跨應(yīng)用共享文本數(shù)據(jù)(這個(gè)也應(yīng)該不會(huì)被蘋果禁用)县匠;
4风科、使用OPEN中提到的手機(jī)的型號(hào)、系統(tǒng)創(chuàng)建時(shí)間乞旦、系統(tǒng)磁盤大小等(這個(gè)也應(yīng)該不會(huì)被蘋果禁用)贼穆;
上面是條件,下面是方法
1兰粉、第一次使用故痊,先從UIPasteboard讀取,有值玖姑,則讀茹碉;沒(méi)值焰络,則從NSUserDefault中讀取戴甩。NSUserDefault中有值則讀取,并保存到UIPasteboard中闪彼;沒(méi)值甜孤,則使用UUID生成唯一值。
2、使用UUID生成唯一值后缴川,保存到NSUserDefault中茉稠,保存到UIPasteboard中。
3把夸、第二次使用而线,如果是跨應(yīng)用讀取,也就是說(shuō)扎即,第一次我是在A應(yīng)用中生成的吞获,現(xiàn)在我在B應(yīng)用中讀取。這種情況谚鄙,如果讀取有值各拷,那么要把讀取的值,保存到B應(yīng)用的NSUserDefault中闷营。
上面3步貌似能解決大部分情況的問(wèn)題了烤黍。可是還有個(gè)問(wèn)題傻盟,比如我恢復(fù)出廠設(shè)置咋辦八偃铩!D锔啊规哲!
我唯一能給出的答案,用我們強(qiáng)大的網(wǎng)絡(luò)诽表!
把保存的UUID值唉锌,條件中的第4步中的手機(jī)型號(hào)、系統(tǒng)創(chuàng)建時(shí)間竿奏、系統(tǒng)磁盤大小等袄简,都在網(wǎng)絡(luò)上保存一份。每次獲取時(shí)泛啸,從網(wǎng)絡(luò)獲取UUID绿语,手機(jī)型號(hào)等、并與本地比較候址。因?yàn)橐话阌脩舾鼡Q設(shè)備后吕粹,設(shè)備型號(hào)都會(huì)有所更新,你不要告訴我你升級(jí)設(shè)備后岗仑,用的還是同一型號(hào)同一款匹耕!
貌似解決了?E馄选!
就上面這些了,我只提供一些思路舞虱。目前在我的項(xiàng)目中欢际,也是這樣使用的,目前還好矾兜,沒(méi)啥大問(wèn)題损趋。
歡迎大家提出一些問(wèn)題,共同探討椅寺、進(jìn)步浑槽!