iOS app通信(app相互调用、网页调用app)
前言
相信做iOS开发的基本都接入过支付宝、微信之类的一些第三方用于支付、分享等功能。最开始使用的时候,一知半解需要在app的URL Schemes中添加标记:
当时不明白这么做的原理。只知道这样配置之后在支付宝、微信完成相应操作后就可以回调打开我们自己的App。
URL Schemes介绍
很显然关键在于URL Schemes,那么它到底是什么呢?有什么用呢?以及怎么用?
URL Shemes是什么
大家知道,苹果的app都是有沙盒机制的,相互之间无法访问数据。那么怎么实现app跳转呢?于是苹果给出了app间跳转的方法:URL Schemes。简单的说,URL Schems就是一个可以让app之间可以跳转的协议。每个app的URL Schemes 是不一样的,如果存在一样的URL Schemes,那么系统只会响应先安装的app的URL Schemes。
URL Schemes的作用
既然URL Schemes是一个跳转协议,那么像我们平时用到的第三方的支付、分享之类的东西都要用到,以及我们自己做的app想给手机上的其它app产品提供某些方面的服务时都能用到。
URL Schemes的用途
相信大家对下面几行代码都不会陌生
1.打开Mail [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"mailto://info@icloud.com"]] 2.打开电话 [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"tel://18688886666"]]; 3.打开SMS [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"sms://18688886666"]];
这不是调用系统一些功能的时候的代码吗?没错,从本质上来说,不管是email、电话、短信,都只是iPhone手机内的一个个的应用。那么这就是苹果对URL Shemes的一次使用。当然双斜杠后边的东西相当于app间通信的时候传递的参数。
相信到这里,大家基本已经明白怎么去玩app跳转了。
其中需要注意的一点是在iOS 9之前只要在plist文件中配置一下你的跳转协议,别人就可以根据这个协议打开你的app了。如下图所示:
但是在iOS 9之后,是无法从Safari启动app的。需要在如下位置注册URL Schemes
这就是我们文章最开始看到的那个截图,我想到这里基本对于跳转的配置已经从根本上理解了。
app间传值的参数接收
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{ NSLog(@"%@",url.absoluteString); return YES;}- (BOOL)application:(UIApplication *)application openURL:(nonnull NSURL *)url sourceApplication:(nullable NSString *)sourceApplication annotation:(nonnull id)annotation{ NSLog(@"%@",url.absoluteString); return YES;}- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options{ NSLog(@"%@",url.absoluteString); return YES;}
相信这几个方法,大家也不陌生,当然app被另外的应用调用时,所配置的协议就是在此处被接收的。
查看苹果api会发现前两个方法在iOS 9之后就不推荐使用了,如果为了兼容不同的版本需要在前两个方法中做处理。但是iOS 9之后推荐使用最后一个方法。其中方法中传入的url即为包含着参数的自定义请求协议,协议头就是我们前边配置图中的那个。当你拿到事先约定好的参数,就可以按着要求去做任何你想做的操作了。
网页调用app的事例
附上在网页上的代码
<!DOCTYPE html> <html> <head> <title>IOS 通过浏览器打开App</title> <meta charset="utf-8"> <style type="text/css"> .back{ position:absolute; top:50px;left:360px;float:left; } </style> </head> <body> <div class="back"> <p> <font size="20px"> 白日依山尽<br> 黄河入海流<br> <a href="nnbApp://123456" >打开APP</a><br> 生活多回味<br> </font> </p> </div> </body> </html>
代码中关键的一步是<a href="nnbApp://123456" >打开APP</a>
其中的url的协议头就是我们提前注册的那个。这样当我们我们在点击时如果手机远程桌面
中安装了app,就可以调起app了。
写在最后的话
现在回首发现其实好多知识点都是接触过的,但是没有穿起来。现在通过对URL Schemes的了解,彻底搞懂了这块东西,以后也能玩出更多的花样。