簡介
Universal Links 是蘋果自iOS9.0推出的用于應(yīng)用之間跳轉(zhuǎn)的一種安全認(rèn)證機(jī)制,主要用來通過HTTPS鏈接來無縫啟動APP。手機(jī)中如果安裝了支持該鏈接的APP就會直接進(jìn)入到APP中。如果沒有安裝APP則會跳轉(zhuǎn)到Safari瀏覽器中,展示H5頁面。
一、Universal Links 配置過程
- 登錄蘋果賬號后,點(diǎn)擊創(chuàng)建的APP 的Bundle ID,跳轉(zhuǎn)到APP 信息頁面。
- 記錄下
Team ID和Bundle ID備用。 - 勾選上 功能列表上的 ”Associated Domains“選項(xiàng)。

- 創(chuàng)建一個text空文本文件,去掉文件后綴,命名為
apple-app-site-association(不能修改,且不能添加后綴)。 - 文件內(nèi)添加json格式數(shù)據(jù),內(nèi)容如下
{
"applinks": {
"apps": [],
"details": [
{
"appID":"8ARUHGUQNH.com.YHKJ.AppSample",
"paths": [ "/AppSample/*"]
}
]
}
}
如果一個域名下面有多端APP,可寫作
{
"applinks":{
"apps":[],
"details":[
{
"appID":"8ARUHGUQNH.com.YHKJ.AppSample",
"paths":["/AppSample/*"]
}
{
"appID":"8ARUHGUQNH.com.YHKJ.appManage",
"paths":["/manageAppSample/*"]
}
]
}
}
apps:為必寫且固定為[ ]
appID是指:TeamID.BundleId的組成
paths:是一個支持的路徑列表字符串?dāng)?shù)組,可以是一個也可以是多個,用于過濾可以跳轉(zhuǎn)到App的鏈接,支持通配符*,通配符表示允許該域名下的任意路徑。
details數(shù)組中可以配置多個APP的信息,如果有多個APP需要支持Universal,則可以直接添加多個。
嚴(yán)格區(qū)分字母大小寫
-
apple-app-site-association文件創(chuàng)建好后 發(fā)給后臺,讓后臺放到域名的服務(wù)器根目錄下,也可以在根目錄中添加.well-known文件夾,將文件上傳到.well-known文件夾下(.點(diǎn)一定不能少),對應(yīng)連接分別為
https://xxx/apple-app-site-association
https://xxx/.well-known/apple-app-site-association
xxx為服務(wù)端的域名
- 打開你的iOS工程,如下添加“Associated Domains”功能 和 域名地址,
applinks:域名地址,Domains中的域名必須是使用applinks開頭。


二、測試Universal Link鏈接
蘋果提供了一個網(wǎng)頁來驗(yàn)證我們編寫的這個apple-app-site-association文件是否合法有效,
https://search.developer.apple.com/appsearch-validation-tool/
如果 Universal Link 配置成功,在iOS自帶Safari瀏覽器中,打開 Universal Link 鏈接,下拉會出現(xiàn)應(yīng)用入口,點(diǎn)擊“打開”可以跳轉(zhuǎn)至原生App;如打開微信的 Universal Link : https://help.wechat.com/app/ 如下圖
二 、Universal Link 的運(yùn)行機(jī)制原理
- 當(dāng)App初次安裝后或者更新版本后的第一次啟動(第二次啟動就不會),向工程配置的applinks:的域名請求apple-app-site-association配置文件。
- App自動的將apple-app-site-association配置文件向iOS系統(tǒng)配置。
- 當(dāng)任何WebView發(fā)起UniversalLink的url的時候,系統(tǒng)遍歷注冊過的通用鏈接,如果命中則直接打開App觸發(fā)Delegate方法。
- 如果沒命中,WebView繼續(xù)跳轉(zhuǎn)加載url。
以上都是系統(tǒng)默默替你做的,我們要做的就是確保配置的正確性。
三 、注意事項(xiàng)
- 服務(wù)器的域名地址必須是HTTPS的,并且SSL證書必須通過蘋果信任。蘋果支持的HTTPS證書列表。
- apple-app-site-association名稱不能變,不能加后綴,只能放在上面說的服務(wù)器位置。但是 iOS 會先去請求.well-known 路徑,如果apple-app-site-association文件請求不到,再去請求根目錄,所以如果想要避免服務(wù)器接收過多GET請求,可以直接把a(bǔ)pple-app-site-association文件放到well-known目錄下。
- 服務(wù)器上apple-app-site-association的更新不會讓iOS本地的apple-app-site-association同步更新,Universal Link的更新 只有在APP第一次安裝 和 更新版本的時候,如果Universal Link有變更,只能重新打包發(fā)版,然后讓用戶更新版本或者卸載重裝。
- 跨域問題,如果由當(dāng)前網(wǎng)頁跳轉(zhuǎn)Universal Link打開APP,當(dāng)前網(wǎng)頁的域名和Universal Link 的域名必須 不能一致,否則不會跳轉(zhuǎn),只會在當(dāng)前的WebView里面跳轉(zhuǎn)。
- 由瀏覽器或其他app應(yīng)用跳轉(zhuǎn)進(jìn)入我自己的APP時接收回調(diào),要在AppDelegate.m/SceneDelegate.m中實(shí)現(xiàn)下面回調(diào)方法:
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray<id<UIUserActivityRestoring>> * _Nullable))restorationHandler {
// NSUserActivityTypeBrowsingWeb 由Universal Links喚醒的APP
if (![userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
return YES;
}
NSURL *jumpUrl = userActivity.webpageURL; // 這個URL就是你跳轉(zhuǎn)的那個URL,下載頁地址,想要傳參數(shù)可以直接在URL后面拼接
// TODO:在這里進(jìn)行跳轉(zhuǎn)具體頁面的操作
return YES;
}
四 、Universal Links 與 URL Scheme
另一種 外部喚起App 的方式是URL Scheme,但是URL Scheme有一些弊端。
Universal Links具有唯一性,比較安全。它是使用標(biāo)準(zhǔn)的HTTPS協(xié)議鏈接到你的web站點(diǎn),所以一般不會被其它的APP所聲明。而URL Scheme是由開發(fā)者自定義的,沒有限制,任何App都可以用同一個名字,有些釣魚App可以 設(shè)置知名的APP 的URL Scheme 來欺騙用戶。URL Scheme可以通過canOpenURL判斷用戶是否安裝App,但是只有安裝了APP才能跳轉(zhuǎn),未安裝則沒有效果。而Universal Links如果安裝了就跳轉(zhuǎn)APP,如果未安裝就跳轉(zhuǎn)網(wǎng)頁展示你網(wǎng)站的內(nèi)容,比較靈活。使用scheme跳轉(zhuǎn)系統(tǒng)會彈框提示,替換成UL鏈接后可以實(shí)現(xiàn)無縫跳轉(zhuǎn)。