Url Scheme实现APP间通信、分享

代码地址如下:
http://www.demodashi.com/demo/12748.html

简介:

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:// + 参数 来完成唤醒跳转客户端界面的。
  • 调用微信、支付宝等客户端完成支付的功能。
  • 三方应用调用系统所带的地图软件。

Url Scheme实现APP间通信、分享

示例:

接下来就以我之前写的UIActivityViewController系统原生分享-仿简书分享iOS开源小项目-WSL两个Demo为例,让我们看下怎么可以让UIActivityViewController系统原生分享-仿简书分享唤起iOS开源小项目-WSL并进行通信、分享:也就是说让 WSL 像微信、QQ、新浪一样支持第三方社交分享。

一、配置WSL的应用信息,添加Url Scheme

要跳转到别人的app,就要知道别人的app的跳转协议是什么,需要传入什么参数,如果我们希望别人打开我们的app,也需要在info.plist中配置跳转协议,然后再重写AppDelegate中的 openUrl方法来处理逻辑参数。

  • WSL 添加Url Scheme
    Url Scheme实现APP间通信、分享

  • 重写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://+ 参数字符串),参数可以为空。
    Url Scheme实现APP间通信、分享

二、在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系统原生分享,过程同一、二步。

Url Scheme实现APP间通信、分享

Url Scheme实现APP间通信、分享

以上就是通过Url Scheme实现APP间相互跳转、传递数据、通信、分享功能的过程。

经过以上操作内容,小伙伴们是不是对其中的步骤有种似曾相识的感觉呢?没错,集成的第三方分享SDK就是通过这种方式来实现分享的,只不过它们把数据、方法都封装到了SDK中。

四、项目结构

Url Scheme实现APP间通信、分享

Url Scheme实现APP间通信、分享

Url Scheme实现APP间通信、分享

Url Scheme实现APP间通信、分享

Url Scheme实现APP间通信、分享

代码地址如下:
http://www.demodashi.com/demo/12748.html

注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权

Url Scheme实现APP间通信、分享

上一篇:iOS仿支付宝首页的刷新布局效果


下一篇:Android蓝牙