一、 通用链接介绍
Apple 推出通用链接:一种能够方便的通过传统 HTTP 链接来启动 APP, 使 用相同的网址打开网站和 APP。
当你的应用支持通用链接,iOS9 之后 , 用户可以点击一个链接跳转到你的网站,并获得无缝重定向到您安装的应用程序,而无需通过 Safari 浏览器。如果你的应用不支持的话,点击链接将会用 Safari 来打开。
二、通用链接的优点
通用链接比自定义的URL链接有几处尤为突出的好处,具体来说,通用链接:
独特性:与自定义的URL链接相比,通用链接不能被其他的应用程序所访问,因为
它们使用的是标准的HTTP 或 HTTPS 链接到你的网站。
安全性:当用户安装应用程序,iOS会检查您已经上传到web服务器文件,以确
保您的网站允许你的应用程序能打开代表它的URL 文件,只要你创建并且上传该
文件,那么你的应用和服务器之间的关联是安全的。
灵活性:当你的应用程序没有被安装的时候,通用链接照样能够工作。当用户没有
安装你的应用程序,点击该链接,将会以用户所期望的以Safari的形式访问。
简单性:通用链接既能支持你的网站,又能支持你的应用
私有性:其他的应用程序能和你的应用程序通信,不管你的应用是否被安装。
传统例子:
传统的密码重置流程是这样的:
1, 您忘记了密码,让你点击“忘记密码”按钮,在应用程序l 输入您的电子邮件,并点击下一步
2, 请检查您的电子邮件,点击重置密码链接
3, Safari中的密码重置页面打开
4, 您输入新密码并保存
5, 切换回应用程序,并登录使用表示新密码
使用通用链接后:
随着通用的链接,我们可以从过程中完全删除 Safari 浏览器。 现在,用户可以重新 设置在应用程序的密码,允许应用程序来复位后也自动登录他们进来。 这是所有可能 的同时还具有重置密码的电子邮件的安全性,以确认身份。
它可以被用来大大提高以前烦人的工作流程的用户体验。
视频演示:http://t.cn/R4pxxB5 (利用“通用链接”改善“密码重置功能)
使用通用链接后有四种打开方式效果:
第一种:安装客户端后点击链接(检测应用是否安装,如果安装直接打开应用)
第二种:长按链接选择 Safari 中打开
第三种:长按链接选择在 XXX 中打开
第四种:删除应用后点击链接(检测应用是否安装,如果没有安装在 Safari 中 打开网址)
三、 通用链接的关键实现条件
有一个注册的域名
域名可通过 SSL 访问(应该是需要有效的证书)
支持上传一个 JSON 文件到域名
至少 iOS 9 beta 2 版本
至少 Xcode 7 beta 2
需要真机测试,模拟器不支持通用链接
web server 需要支持 https,客户端需要通告 https 访问,并且不支持任何重定向
四、 通用链接实现步骤
1, 开启 Associated Domains 域:
进入苹果Apple Developer --- Member Center - Certificates, Identifiers & Profiles – Identifiers - App IDs –Edit 然后开启打钩 Associated Domains 后保存。
2, 添加 Associated Domains 域:
说明:你的 APP 域名, 必须用 applinks: 前置它:还添加一些你可能 拥有的子域和扩展(www.domain.com, news.domain.com 等等)。
添加域名,点击Associated Domains的“+”添加前缀为applinks:的域名,如下图所示
作用:配置之后你的 APP 会自动从你的域名请求一个特殊的 JSON 文 件 apple-app-site-association。当你第一次启动 APP,它会从 https://domain.com/apple-app-site-association 下载这个文件。
操作:项目 targets->Capabilities->Associated Domains
3, 上传 apple-app-site-association 文件到服务器的根目录:
注意事项(1)
1, paths 路径是大小写敏感的
2, paths 内容可明确哪些通用链接需要被处理,哪些不需要
3, NOT 使用:为了明确指出不被处理的链接,可增加 “NOT”在链接前面
例 如 "paths": [ "/wwdc/news/", "NOT /videos/wwdc/2010/", "/videos/wwdc/201?/"]
4, 你可以使用 * 明确所有的网页
5, 也可以使用一个明确的的 URL,例如 /wwdc/news/
6, 也可以追加 * 到你的 URL ,例如 /videos/wwdc/2015/* 也可以使用 * 来匹配任何字符,使用 ? 来匹配一个字符,可以在路径 中使用这种混搭的形式, 例如 /foo/*/bar/201?/mypage
注意事项(2)
1, “appID”组成部分:TeamID + BundleId TeamID
2, BundleId 一定要和 APP 的 BundleId 一致。
3, apple-app-site-association 文件不能带后缀
4, apple-app-site-association 文件需要上传到网站根目录
5, 每一个代表着应用的 字典,必须包含一个 appID 和 paths, appID 是teamID 和 bundleID,paths 是一个字符串的数组 明确着你的应用支持的通用链接和你的应用程序不支持的通用连接内容。
其中apps项必须对应一个空的数组。details项对应一个字典的数组,网站所能支持的每个app一个字典。
appID对应项由前缀和ID两部分组成,可以在developer.apple.com中的Identifiers→AppIDs中点击对应的App ID查看。
paths对应域名中的path,用于过滤可以跳转到App的链接,支持通配符‘*’,‘?’以及‘NOT’进行匹配,匹配的优先级是从左至右依次降低。
6, 内容如下例子
{
"applinks": {
"apps": [],
"details": {
"TBEJCS6FFP.com.domain.App": {
"paths":[ "*" ]
}
}
}
}
服务器配置要求:
域名需要SSL证书,如果不支持HTTPS,则需要对apple-app-site-association进行SSL认证。认证命令如下:
服务器配置要求站点必须是youdomain.com/apple-app-site-association,请求头是‘application/pkcs7-mime’,返回HTTP码是200。
4, 在 APP 里处理通用链接:
例子:
为了在 APP 里支持通用链接, 你需要在 AppDelegate 里实现[application(_:continueUserActivity:restorationHandler:)]。
- 一些注意的事项
5.1. apple-app-site-association不需要.json后缀。
5.2. 如果要对没有path的域名进行支持(如:www.163.com),在json文件的paths中用通配符’*’是不行的,需要在paths数组中加入’/’进行匹配。
5.3. 对json文件的请求仅在App第一次启动时进行,如果此时网络连接出了问题apple会缓存请求,等有网的时候再去请求,而实际测试抓包并没有请求故通用连接会失效。
5.4. paths匹配的优先级是从左至右依次降低,但需要明确,否则会出问题。比如"paths":["NOT /together/",""],在IOS9.2上path为/together/*都不会跳到App,但是在IOS9.0上会跳到。