本文讲的是iOS URL scheme的一个典型应用。如果你对iOS URL scheme还不是很了解,建议可以先读一下《你不知道的iOS URL Scheme之基础篇(一)》,这样可以更加方便的理解本文。
如果都准备好了,那我们就开始本文的deeplink之旅喽!
你不知道的iOS URL Scheme之基础篇(一)
你不知道的iOS URL Scheme之deeplink篇(二)
你不知道的iOS URL Scheme之唤起劫持篇(三)
走近deeplink
指向某个具体内容页面的链接称为deeplink(深度链接)。
在 web 开发领域,例如 https://developer.apple.com/ 是指向某个首页的链接, https://developer.apple.com/develop/ 是指向具体内容页的链接。
在移动端开发领域,也想做到像定位一个网页一样,用一种特殊的 URL 来定位一个应用甚至应用里某个具体的功能。
- 定位某个应用,发挥作用的就是URL 的 scheme 部分,但是需要注意的是应用的URL scheme 并不唯一,也就是说一个应用可以“起多个名”,不同应用的URL scheme也可能因为名字一样发生冲突(后面会专门写一篇文章来介绍这一块,大家敬请期待吧)。
- 定位到某个应用的某个具体页面,即点击一个链接后,直接链接到App内部的某个页面,而不仅仅是启动 App,要实现这一效果就需要用到deeplink。
deeplink实质上就是在URL scheme的基础上,附加了更多的信息传递给被唤起的App侧。
举个例子A同学通过某App1发给你某个商品的介绍链接,假如App2使用了deeplink技术,当点击链接,在你安装了App2的情况下(假如你没有安装App2,也会有相应的处理技术,下面会讲到)唤起App同时打开进入了相应的商品页面。这样你可以直接在这个页面购买该商品,而不是跳转到首页再去搜索并寻找。
deeplink的好处
总的来说,deeplink的好处在于它可还原场景,不打断用户体验,能有效提高App留存率及转化率,因此在App市场推广运营中起到很好的作用。
- 在 web 和 App 的切换过程中保留上下文;
- App 间带上下文切换(用于实现 App 间参数的传递);
deeplink的处理流程
假如App A要调用App B,则(如下图所示)
-
App B要进行自定义scheme的配置,在 info plist 里设置,如下图所示:
App B添加参数处理的编码,需要在AppDelegate.m中实现delegate 方法:
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options NS_AVAILABLE_IOS(9_0); // no equiv. notification. return NO if the application can't open for some reason
- App A进行调用,首先判断设备是否安装App B。
- 如果未安装,则跳转到App Store进行下载。
- 如果已安装,则调用App B配置好的URL scheme,直接打开App B的相关界面。
deferred deeplink
deferred deeplink(延迟深度链接),可以先判断用户是否已经安装了App应用,如果没有则先引导至App Store中下载App,在用户安装App后跳转到指定App页面deeplink中。
为实现该效果,需要实现:
- 判断是否已经安装了 App,如果已经安装了直接 deeplink 到 App,否则跳转 App Store。
- 用户匹配(user matching),如何把一个 install 对应到某一次网页或者某一次点击。
主要的应用场景有:
- 追踪广告效果
- 追踪用户推荐/邀请链接
- 在 App 内保持网页浏览的上下文,如登录信息,购物车等
deeplink和deferred deeplink在移动端广告的应用
deeplink、deferred deeplink在移动端广告领域有较大的应用,以Facebook广告为例。
Facebook广告支持deeplink和deferred deeplink。接入方App侧要实现该项功能需要做以下配合:
- 对于deeplink需要通过Apple的delegate来获取;
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options NS_AVAILABLE_IOS(9_0); // no equiv. notification. return NO if the application can't open for some reason
- 对于deferred deeplink需要调用Facebook SDK提供的接口来获取:
+ (void)fetchDeferredAppLink:(nullable FBSDKURLBlock)handler;
调用时机放在application delegate的applicationDidBecomeActive。同时需要注意的是该接口是一个异步操作,所以可能会返回空,需要做好处理。
Facebook官方提供了工具来测试应用的深度链接是否正常运作:测试工具
使用该工具需要注意以下事项:
- 需要在用来测试深度链接的设备上登录 Facebook 应用;
- 输入的深度链接将以在你的 Facebook 应用中作为通知发送,轻触通知即可启用深度链接。
- 测试deferred deeplink时需要确保唤醒应用时是该次应用安装在设备上的首次启动。