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
给 WSL 添加Url Scheme要跳转到别人的app,就要知道别人的app的跳转协议是什么,需要传入什么参数,如果我们希望别人打开我们的app,也需要在info.plist中配置跳转协议,然后再重写AppDelegate中的 openUrl方法来处理逻辑参数。

重写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中。
四、项目结构


Url Scheme实现APP间通信、分享
注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?