iOS开发之常用技术点iOS开发iOS开发

iOS-UniversalLink开发

2018-12-13  本文已影响8人  二斤寂寞

Universal Link 介绍

Universal Link是苹果在WWDC 2015上提出的iOS 9的新特性之一。此特性类似于深层链接,并能够方便地通过打开一个Https链接来直接启动您的客户端应用(手机有安装App)。对比起以往所使用的URL Sheme, 这种新特性在实现web-app的无缝链接时能够提供极佳的用户体验。

这具体是一种怎样的情景呢?举个例子,你的用户在微信里面浏览一个你们公司的网页,而此时用户手机也同时安装有你们公司的App ;而universal link 能够使的用户在打开某个详情页时直接打开你的app 并到达app中相应内容的页面,从而实施用户想要的操作(例如查看某条新闻,例如查看某个商品的明细)

以下分别为URL Scheme方式及Universal Link的方式呈现场景恢复的过程
以下为URL Scheme方式: (第一张图是在微信中浏览web,下同)

scheme

下面是用Universal Link方式:

ul

通过上述对比得知,Universal Link能够直接从微信中打开App,比起以往的URL Scheme的方式能够大大改善用户体验。

Univerasl Link的准备工作

注:可以使用三方服务,MobLink已经帮您完成了上面所有的工作,免费为您提供Universal Link服务。使用MobLink提供的技术方案,无论您是否iOS9以上,都能够助您实现 Web与App 之间的完美交互。

集成步骤

  1. 开启Associated Domains服务
    image.png

注意:有的app会区分线上包和测试包,不同账号下的都需要设置App ID才行,前往不要忘记。

2.开启Associated Domains服务
在xcode工程的Capabilities -> Associated Domains中添加跳转域名,域名的格式为:
applinks:www.example.com

image.png

注意:
你的服务器必须支持SSL
Domains可以添加多个
Domains必须以applinks: 开头

3.配置apple-app-site-association文件,官方文档如下:

{
    "applinks": {
        "apps": [],
        "details": [
            {
                "appID": "9JA89QQLNQ.com.apple.wwdc",
                "paths": [ "/wwdc/news/", "/videos/wwdc/2015/*"]
            },
            {
                "appID": "ABCD1234.com.apple.wwdc",
                "paths": [ "*" ]
            }
        ]
    }
}

当我们的App在设备上第一次运行时,如果支持Associated Domains功能,那么iOS会自动去GET定义的Domain下的apple-app-site-association文件。
需要留意iOS会先请求 https://domain.com/.well-known/apple-app-site-association
如果此文件请求不到,再去请求 https://domain.com/apple-app-site-association。 所以如果想要避免服务器接收过多GET请求,可以直接把apple-app-site-association放在./well-known/目录下。

4.Appdelegate增加如下代码

#pragma mark Universal Link
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray<id<UIUserActivityRestoring>> * _Nullable))restorationHandler {
    if ([userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
        NSURL *url = userActivity.webpageURL;
       // TODO 根据需求进行处理
    }
      // TODO 根据需求进行处理
    return YES;
}

在Safari中点击链接打开App后,会发现App的右上角的navigationBar会有一串网址的链接箭头,
如果你点击了它,它会跳转到Safari,同时系统会默认你选择用Safari来打开该域名的链接,而不用app打开,也就是说下次你再点击该链接,它只会在Safari中打开,不会在App中打开了。

那么如何开启app跳转呢?有两种方法:
第一种,在Safari页面中,手指往下拉一下页面,会显示一个“隐藏”的banner,俗称为 smart banner,右侧有一个button,点击它,就开启App跳转功能了。
第二种,长按跳转链接,底下会弹出一些选项,选择在App中打开,同样可以开启这个功能。

apple-app-site-association 文件注意格式是否正确 中文字符不识别

总结

参考文章:
苹果官方文档
mob
iOS的UniversalLink开发总结

上一篇下一篇

猜你喜欢

热点阅读