iOS 支持从一个 App 跳转到另一个 App,这其中的原理就是 URL SCheme。这一功能特别炫酷,当你在 iphone 上使用 Safari 浏览器时,通过输入正确的 url 唤起对应的 app,你也可以在某个 App 内直接跳转到另外一个 App。虽然 iOS 系统的沙盒机制阻挡了不同 App 之间的交流,但是 URL Scheme 这一特性却又允许开发者实现不同 App 间的通信。
系统 URL Scheme
系统已经给开发者提供了几个系统 App 对应的 URL Scheme,从官方文档中可以找到这几种通用 URL SCheme 的调用方式。这些功能包括打电话、发邮件、发短信等等。
发邮件
// html
<a href="mailto:frank@wwdcdemo.example.com">John Frank</a>
// objective-c
mailto:frank@wwdcdemo.example.com
// 包含主题、消息、发件人等信息
mailto:foo@example.com?cc=bar@example.com&subject=Greetings%20from%20Cupertino!&body=Wish%20you%20were%20here!
注:如果没有安装邮件类 App,系统会给出一个错误提示。
打电话
// html
<a href="tel:1-408-555-5555">1-408-555-5555</a>
// objective-c
tel:1-408-555-5555
注:如果是在 web 页面点击一个电话链接,系统会弹出提示框,但是 app 内开发者打开一个打电话的链接,系统不会弹出提示框,但是希望 native 通过 Alert
的方式提示用户。
发短信
// html
<a href="sms:">Launch Messages App</a>
<a href="sms:1-408-555-1212">New SMS Message</a>
// objective-c
sms:
sms:1-408-555-1212
地图
地图 scheme 用于展示地理位置信息或者生成两点之间的驾驶导航,但是跟其他 scheme 不同,系统地图 app 的唤起是采用通用 http 格式的链接进行启动的。同时需要注意,连接后面通过参数指定具体的功能。
// 参数类型
t:地图视图模式,m (标准视图)、k (卫星视图)、h (混合视图)、r (运输视图)
q:查询内容
address:地址内容
near:提示信息
ll:地图中心的定位坐标
z:缩放等级
spn:围绕中心点的转速
saddr:源地址
daddr:目的地地址
dirflg:传输类型
sll:搜索定位坐标
sspn:屏幕的转速
// link sample
http://maps.apple.com/?q=Mexican+Restaurant
打开 iTunes
用于链接到 iTunes 音乐商店
// html
<a href="http://phobos.apple.com/WebObjects/MZStore.woa/wa/viewAlbum?i=156093464&id=156093462&s=143441">
<img height="15" width="61" alt="Randy Newman - Toy Story
- You've Got a Friend In Me" src="http://ax.phobos.apple.com.edgesuite.net/images/
badgeitunes61x15dark.gif"></img>
</a>
// native
http://phobos.apple.com/WebObjects/MZStore.woa/wa/viewAlbum?i=156093464&id=156093462&s=143441
第三方 URL Scheme
常用的 App 对应的 URL Scheme 列举如下,不过,下方列举出的 URL Scheme
只是基本的 Scheme,如果想了解具体的功能及其参数就需要查看官方文档或者直接使用第三方的SDK了。
淘宝宝贝搜索 taobao://[http://s.taobao.com/?q=xxx]
淘宝店铺搜索 taobao://[http://shopsearch.taobao.com/browse/shop_search.htm?q=**]
QQ的url是 mqq://
微信是weixin://
淘宝taobao://
点评dianping:// dianping://search
微博 sinaweibo://
名片全能王camcard://weico
微博weico://
支付宝alipay://
豆瓣fm:doubanradio://
微盘 sinavdisk://
网易公开课ntesopen://
美团 imeituan://
京冬openapp.jdmoble://
人人renren://
我查查 wcc://
1号店wccbyihaodian://
有道词典yddictproapp://
知乎zhihu://
优酷 youku://
自定义 URL Scheme
给 iPhone 手机安装 App 时,如果这个 App 设置了 URL Scheme,安装完成后 iOS 系统会自动注册该 URL Scheme,这样其他 App 或者浏览器就可以通过 URL 的方式找到对应的 App 并唤起该 App。
除了唤起 App 这样基本的功能外,不同 App 之间消息传递也经常用该方案。像微信、微博分享、微信、支付宝付款,等等。
那么,看一下如何给一个 App 自定义 URL Scheme。
其实很简单:
这里,我们设置了 URL Scheme 为 "fusion"。
但是这样还没完事,你只是注册了当前 App 的 Scheme,但是,应用是否允许唤起还需要做一步操作,那就是监听唤起事件。在 AppDelegate.m文件中,实现相应的代理方法:
// return NO 则不允许唤起(实际不生效,费解)
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options;
特别的,iOS9之后,新增了白名单概念。如果没有在 info.plist 添加白名单,则会有如下结果:
BOOL result = [[UIApplication sharedApplication] canOpenURL:url]; // result = NO;
同时,控制台打印类似下面的错误提示信息:
-canOpenURL: failed for URL: "XXX://" - error: "This app is not allowed to query for scheme TestB"
解决这一问题很简单,添加白名单即可。
info.plist 里添加 key 为 LSApplicationQueriesSchemes 的字段,类型为 Array。依次填入 App 支持的第三方 app 的 scheme 即可。
调用自定义 URL Scheme
继续上面这个例子,我们看看如何通过 URL Scheme 唤起这个 app。
一开始也提到了,要么通过 Safari 要么通过应用内跳转,当然,最简单的方法就是前者了。
此时,Demo 客户端就被唤起了。
那么,通过其他 App 来唤起 fusion App 该如何做呢?
if ([[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:@"fusion://"]]){
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"fusion://"]];
} else {
//提示用户未安装app
}
先判断系统是否安装相应 Scheme 的 App,即是否注册 Scheme,然后再打开对应的 App。