Url Scheme实现APP间通信、分享
简介:
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
添加URL Scheme.png
-
重写WSL中AppDelegate中的openUrl方法,当WSL被唤起时会执行openUrl方法,我们可以在方法里根据传入的参数的做出处理。如果只想允许在特定情况下才能被唤起,比如说分享,就可以对传入的openUrl加以验证,符合要求return YES ,否则返回NO。
/**
iOS 9.0 以下
*/
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{
NSString *text = [[url host] stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
NSLog(@"URL scheme:%@", [url scheme]);
NSLog(@"URL query: %@", [url query]);
return YES;
}
/**
iOS 9.0 之后
三方唤起本程序后执行的方法
return YES 表示允许唤起本程序
*/
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options{
NSLog(@"URL scheme:%@", [url scheme]);
//参数
NSLog(@"URL host:%@", [url host]);
UIAlertView *alertView=[[UIAlertView alloc] initWithTitle:@"分享" message:[url host] delegate:self cancelButtonTitle:nil otherButtonTitles:@"分享完成", nil];
[alertView show];
return YES;
}
- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex{
//返回URL scheme = wsl123456的主应用
NSURL * url = [NSURL URLWithString:@"wsl123456://success"];
[[UIApplication sharedApplication] openURL:url options:nil completionHandler:^(BOOL success) {
}];
}
- 通过浏览器打开唤起WSL,测试一下,输入的地址是" WSLAPP://wslmeiksjkfdfkfkfhskfhskfhskj "(Url Scheme://+ 参数字符串),参数可以为空。
二、在UIActivityViewController系统原生分享中添加事件,通过Url Scheme来唤起WSL,并传参
- (IBAction)shareToWSL:(id)sender {
//不带参数
NSString * wslUrlScheme = @"WSLAPP://";
//如果参数含有特殊字符或汉字,需要转码,否则这个URL不合法,就会唤起失败;参数字符串的格式可以自定义,只要便于自己到时候解析就行
NSString * parameterStr = [@"name=wsl&weight=保密" stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
//不带参数
// NSURL * url = [NSURL URLWithString:wslScheme];
//带参数
//WSLAPP://name=wsl&weight=保密
NSURL * url = [NSURL URLWithString:[wslUrlScheme stringByAppendingString:parameterStr]];
//iOS 10以下
// [[UIApplication sharedApplication] openURL:url];
//iOS 10以上
[[UIApplication sharedApplication] openURL:url options:nil completionHandler:^(BOOL success) {
}];
}
三、唤起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。