简介:
URL Scheme就是一个可以让app相互之间可以跳转的对外接口。通过给APP定义一个唯一的URL路径来从外部快速的打开这个指定的APP,每个app的URL Scheme都是不一样的,如果存在一样的URL Scheme,那么系统就会响应先安装那个app的URL Scheme,因为后安装的app的URL Scheme被覆盖掉了,是不能被调用的。
应用:
- 第三方分享的SDK就是通过这种方式来实现分享的,我们将需要分享的数据传递给SDK,SDK通过OpenURL来打开第三方应用传递数据,返回时SDK来处理OpenUrl的参数,实现查看分享的回调。
- 从浏览器中某一页面的点击事件可以打开对应客户端的某一个界面,就是通过协议 URL Scheme:// + 参数 来完成唤醒跳转客户端界面的。
- 调用微信、支付宝等客户端完成支付的功能。
- 三方应用调用系统所带的地图软件。
示例:
接下来就以我之前写的UIActivityViewController系统原生分享-仿简书分享和iOS开源小项目-WSL两个Demo为例,让我们看下怎么可以让UIActivityViewController系统原生分享-仿简书分享唤起iOS开源小项目-WSL并进行通信、分享:也就是说让 WSL 像微信、QQ、新浪一样支持第三方社交分享。
一、配置WSL的应用信息,添加Url Scheme
要跳转到别人的app,就要知道别人的app的跳转协议是什么,需要传入什么参数,如果我们希望别人打开我们的app,也需要在info.plist中配置跳转协议,然后再重写AppDelegate中的 openUrl方法来处理逻辑参数。
给 WSL 添加Url Scheme
重写WSL中AppDelegate中的openUrl方法,当WSL被唤起时会执行openUrl方法,我们可以在方法里根据传入的参数的做出处理。如果只想允许在特定情况下才能被唤起,比如说分享,就可以对传入的openUrl加以验证,符合要求return YES ,否则返回NO。
1 | //第三方应用打开本应用启动 |
- 通过浏览器打开唤起WSL,测试一下,输入的地址是” WSLAPP://wslmeiksjkfdfkfkfhskfhskfhskj “(Url Scheme://+ 参数字符串),参数可以为空。
二、在UIActivityViewController系统原生分享中添加事件,通过Url Scheme来唤起WSL,并传参
1 | - (IBAction)shareToWSL:(id)sender { |
三、唤起WSL之后需要做的处理
唤起WSL之后,WSL根据传入的参数进行界面数据的处理,处理完成之后,我们需要自动返回主应用UIActivityViewController系统原生分享,同时传递数据处理的结果。相当于WSL回调唤起UIActivityViewController系统原生分享,过程同一、二步。
- 给UIActivityViewController系统原生分享 也添加Url Scheme,便于从WSL返回主应用UIActivityViewController系统原生分享。
- 重写UIActivityViewController系统原生分享中AppDelegate中的openUrl方法,在返回UIActivityViewController系统原生分享应用时根据从WSL返回的数据处理结果做出反应。
以上就是通过Url Scheme实现APP间相互跳转、传递数据、通信、分享功能的过程。
经过以上操作内容,小伙伴们是不是对其中的步骤有种似曾相识的感觉呢?没错,集成的第三方分享SDK就是通过这种方式来实现分享的,只不过它们把数据、方法都封装到了SDK中。
iOS 9 通用链接(Universal Links) 通过传统的HTTP链接来启动APP。