一、 通用鏈接介紹
Apple 推出通用鏈接:一種能夠方便的通過傳統(tǒng) HTTP 鏈接來啟動 APP, 使 用相同的網(wǎng)址打開網(wǎng)站和 APP。
當(dāng)你的應(yīng)用支持通用鏈接,iOS9 之后 , 用戶可以點(diǎn)擊一個鏈接跳轉(zhuǎn)到你的網(wǎng)站,并獲得無縫重定向到您安裝的應(yīng)用程序,而無需通過 Safari 瀏覽器。如果你的應(yīng)用不支持的話,點(diǎn)擊鏈接將會用 Safari 來打開。
二、通用鏈接的優(yōu)點(diǎn)
通用鏈接比自定義的URL鏈接有幾處尤為突出的好處,具體來說,通用鏈接:
獨(dú)特性:與自定義的URL鏈接相比,通用鏈接不能被其他的應(yīng)用程序所訪問,因?yàn)?br>
它們使用的是標(biāo)準(zhǔn)的HTTP 或 HTTPS 鏈接到你的網(wǎng)站。
安全性:當(dāng)用戶安裝應(yīng)用程序,iOS會檢查您已經(jīng)上傳到web服務(wù)器文件,以確
保您的網(wǎng)站允許你的應(yīng)用程序能打開代表它的URL 文件,只要你創(chuàng)建并且上傳該
文件,那么你的應(yīng)用和服務(wù)器之間的關(guān)聯(lián)是安全的。
靈活性:當(dāng)你的應(yīng)用程序沒有被安裝的時(shí)候,通用鏈接照樣能夠工作。當(dāng)用戶沒有
安裝你的應(yīng)用程序,點(diǎn)擊該鏈接,將會以用戶所期望的以Safari的形式訪問。
簡單性:通用鏈接既能支持你的網(wǎng)站,又能支持你的應(yīng)用
私有性:其他的應(yīng)用程序能和你的應(yīng)用程序通信,不管你的應(yīng)用是否被安裝。
傳統(tǒng)例子:
傳統(tǒng)的密碼重置流程是這樣的:
1, 您忘記了密碼,讓你點(diǎn)擊“忘記密碼”按鈕,在應(yīng)用程序l 輸入您的電子郵件,并點(diǎn)擊下一步
2, 請檢查您的電子郵件,點(diǎn)擊重置密碼鏈接
3, Safari中的密碼重置頁面打開
4, 您輸入新密碼并保存
5, 切換回應(yīng)用程序,并登錄使用表示新密碼
使用通用鏈接后:
隨著通用的鏈接,我們可以從過程中完全刪除 Safari 瀏覽器。 現(xiàn)在,用戶可以重新 設(shè)置在應(yīng)用程序的密碼,允許應(yīng)用程序來復(fù)位后也自動登錄他們進(jìn)來。 這是所有可能 的同時(shí)還具有重置密碼的電子郵件的安全性,以確認(rèn)身份。
它可以被用來大大提高以前煩人的工作流程的用戶體驗(yàn)。
視頻演示:http://t.cn/R4pxxB5 (利用“通用鏈接”改善“密碼重置功能)
使用通用鏈接后有四種打開方式效果:
第一種:安裝客戶端后點(diǎn)擊鏈接(檢測應(yīng)用是否安裝,如果安裝直接打開應(yīng)用)
第二種:長按鏈接選擇 Safari 中打開
第三種:長按鏈接選擇在 XXX 中打開
第四種:刪除應(yīng)用后點(diǎn)擊鏈接(檢測應(yīng)用是否安裝,如果沒有安裝在 Safari 中 打開網(wǎng)址)
三、 通用鏈接的關(guān)鍵實(shí)現(xiàn)條件
有一個注冊的域名
域名可通過 SSL 訪問(應(yīng)該是需要有效的證書)
支持上傳一個 JSON 文件到域名
至少 iOS 9 beta 2 版本
至少 Xcode 7 beta 2
需要真機(jī)測試,模擬器不支持通用鏈接
web server 需要支持 https,客戶端需要通告 https 訪問,并且不支持任何重定向
四、 通用鏈接實(shí)現(xiàn)步驟
1, 開啟 Associated Domains 域:
進(jìn)入蘋果Apple Developer --- Member Center - Certificates, Identifiers & Profiles – Identifiers - App IDs –Edit 然后開啟打鉤 Associated Domains 后保存。
2, 添加 Associated Domains 域:
說明:你的 APP 域名, 必須用 applinks: 前置它:還添加一些你可能 擁有的子域和擴(kuò)展(www.domain.com, news.domain.com 等等)。
添加域名,點(diǎn)擊Associated Domains的“+”添加前綴為applinks:的域名,如下圖所示
作用:配置之后你的 APP 會自動從你的域名請求一個特殊的 JSON 文 件 apple-app-site-association。當(dāng)你第一次啟動 APP,它會從 https://domain.com/apple-app-site-association 下載這個文件。
操作:項(xiàng)目 targets->Capabilities->Associated Domains
3, 上傳 apple-app-site-association 文件到服務(wù)器的根目錄:
注意事項(xiàng)(1)
1, paths 路徑是大小寫敏感的
2, paths 內(nèi)容可明確哪些通用鏈接需要被處理,哪些不需要
3, NOT 使用:為了明確指出不被處理的鏈接,可增加 “NOT”在鏈接前面
例 如 "paths": [ "/wwdc/news/", "NOT /videos/wwdc/2010/", "/videos/wwdc/201?/"]
4, 你可以使用 * 明確所有的網(wǎng)頁
5, 也可以使用一個明確的的 URL,例如 /wwdc/news/
6, 也可以追加 * 到你的 URL ,例如 /videos/wwdc/2015/* 也可以使用 * 來匹配任何字符,使用 ? 來匹配一個字符,可以在路徑 中使用這種混搭的形式, 例如 /foo/*/bar/201?/mypage
注意事項(xiàng)(2)
1, “appID”組成部分:TeamID + BundleId TeamID
2, BundleId 一定要和 APP 的 BundleId 一致。
3, apple-app-site-association 文件不能帶后綴
4, apple-app-site-association 文件需要上傳到網(wǎng)站根目錄
5, 每一個代表著應(yīng)用的 字典,必須包含一個 appID 和 paths, appID 是teamID 和 bundleID,paths 是一個字符串的數(shù)組 明確著你的應(yīng)用支持的通用鏈接和你的應(yīng)用程序不支持的通用連接內(nèi)容。
其中apps項(xiàng)必須對應(yīng)一個空的數(shù)組。details項(xiàng)對應(yīng)一個字典的數(shù)組,網(wǎng)站所能支持的每個app一個字典。
appID對應(yīng)項(xiàng)由前綴和ID兩部分組成,可以在developer.apple.com中的Identifiers→AppIDs中點(diǎn)擊對應(yīng)的App ID查看。
paths對應(yīng)域名中的path,用于過濾可以跳轉(zhuǎn)到App的鏈接,支持通配符‘*’,‘?’以及‘NOT’進(jìn)行匹配,匹配的優(yōu)先級是從左至右依次降低。
6, 內(nèi)容如下例子
{
"applinks": {
"apps": [],
"details": {
"TBEJCS6FFP.com.domain.App": {
"paths":[ "*" ]
}
}
}
}
服務(wù)器配置要求:
域名需要SSL證書,如果不支持HTTPS,則需要對apple-app-site-association進(jìn)行SSL認(rèn)證。認(rèn)證命令如下:
服務(wù)器配置要求站點(diǎn)必須是youdomain.com/apple-app-site-association,請求頭是‘a(chǎn)pplication/pkcs7-mime’,返回HTTP碼是200。
4, 在 APP 里處理通用鏈接:
例子:
為了在 APP 里支持通用鏈接, 你需要在 AppDelegate 里實(shí)現(xiàn)[application(_:continueUserActivity:restorationHandler:)]。
- 一些注意的事項(xiàng)
5.1. apple-app-site-association不需要.json后綴。
5.2. 如果要對沒有path的域名進(jìn)行支持(如:www.163.com),在json文件的paths中用通配符’*’是不行的,需要在paths數(shù)組中加入’/’進(jìn)行匹配。
5.3. 對json文件的請求僅在App第一次啟動時(shí)進(jìn)行,如果此時(shí)網(wǎng)絡(luò)連接出了問題apple會緩存請求,等有網(wǎng)的時(shí)候再去請求,而實(shí)際測試抓包并沒有請求故通用連接會失效。
5.4. paths匹配的優(yōu)先級是從左至右依次降低,但需要明確,否則會出問題。比如"paths":["NOT /together/",""],在IOS9.2上path為/together/*都不會跳到App,但是在IOS9.0上會跳到。