最近公司有個需求,需要從微信或者QQ等第三方APP直接跳轉到我們的APP,其他APP跳轉到我們APP一般的url Schemes 就可以跳轉成功,但是因為微信對著方面做了處理,我們無法直接跳轉到我們的APP,只能通過safari來打開。在這種情況下,我對微信直接打開我們的APP做了一個技術調研,發現了可以使用通用鏈接來完成這一個需求,于是我對通用鏈接(Universal Links)做了一下了解,發現有的第三方比如魔窗可以實現,但是因為我們不希望引入太多第三方的SDK所以放棄了這一個選擇,我們選擇原生來實現這一需求!
1.通用鏈接就是HTTP協議的普通URL,通過在服務器上配置一些文件,配合應用.實現客戶點擊網頁鏈接之后直接打開信E投等應用.客戶在微信\QQ中點擊鏈接時不再需要點擊右上'在Safari瀏覽器打開'才能打開軟件,實現客戶操作的無縫跳轉,讓客戶體驗更加連貫,更順暢.
服務器可以控制哪些路徑可以打開應用,哪些不可以喚醒.
服務器只需要配置一次,可以實現多個應用的都可以使用這種技術.
細化鏈接直接跳轉到應用的某個具體頁面.如首頁,我的頁面等具體的某一個頁面.
2.通用鏈接分析
外部喚起可行方案
URL Scheme(已經實現) 了解URLScheme
優點:支持低版本iOS系統
缺點:用戶體驗一般,需要在Safari瀏覽器中打開,在微信 QQ中被屏蔽.
Universal Links 了解通用鏈接
優點:無縫跳轉,用戶體驗好.可以在微信 QQ中跳轉.不會被屏蔽.
缺點:需要服務器配合支持,iOS9之后版本才支持.
本次調研的是Universal Links技術
3.創建配置文件
創建名稱為apple-app-site-association的純文本文件,(*不需要后綴名,文件不得大于128kb)
配置文件,文件內容為Json字符串,只需要配置details的內容.
appID
appID為開發者的Team ID + bundle ID
TeamID可以打開開發者網站點擊Membership選項找到Team ID 即可.
bundle ID即 Bundle Identity.
paths
paths 是URL包含哪些路徑可以喚醒APP
一個文件中可以配置多個APP.
每個APP可以單獨指定哪些路徑可以喚醒APP.
可以使用統配符*匹配任何字段,?匹配單個字段
* 就會匹配整個網站,所有路徑都可以喚醒.
路徑有優先級順序, 保持高優先級的路徑在前面.
路徑區分大小寫
范例 參考其他51家公司的通用鏈接配置
"paths": [ "/wwdc/news/", "NOT /videos/wwdc/2010/*", "/videos/wwdc/201?/*"]
4.服務器配置
服務器需要支持HTTPS,并且證書是有效的.如果沒有證書.可以試試阿里云的免費SSL證書.
將配置好的apple-app-site-association文件上傳至服務器的根目錄或者.well-known目錄.
打開https://你的域名.com/apple-app-site-association訪問查看是否有效.
打開蘋果官方檢測工具測試你的配置是否有效.在Link to Application欄目出現提示表示配置文件正確.
注意! 不同的域需要配置不同的通用鏈接文件.
5.描述文件配置
進入蘋果開發者網站點擊Identifiers找到對應的bundle ID 點擊編輯,打開Associated Domains 功能.
更新對應的Provisioning Profiles文件,并添加到工程中.
6.工程配置
打開工程-Capablities-Associated domains-添加你需要允許喚醒APP的相應的域名.
這里就是你存放apple-app-site-association文件的域名.例如
applinks:www.baidu.com
7.編碼
在appdelegate中實現這個方法,示例代碼如下.
//MARK:通用鏈接方法
- (BOOL)application:(UIApplication *)application
continueUserActivity:(NSUserActivity *)userActivity
restorationHandler:(void (^)(NSArray *restorableObjects))restorationHandler
{
if ([userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
NSURL *webpageURL = userActivity.webpageURL;
NSString *host = webpageURL.host;
if ([host isEqualToString:@"baidu.com"]) {
NSLog(@"網址首頁");
}
}
return YES;
}
參考文檔
51 iOS 9 Apps That Support Universal Links (updated Dec 19th)