iOS-应用间通信之自定义URL Schemes

2024-08-26 08:08

本文主要是介绍iOS-应用间通信之自定义URL Schemes,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


一、URL Schemes知识的了解

URL Scheme是类似http://, ftp://这样的东西,同样你也可以为自己的应用自定URL Scheme,其他应用通过此标识就可以访问你的应用,如果自定的URL Scheme 和系统应用的相同,则会调用系统应用,而不会调用自定的应用程序。
例如:invoking://com.hello/yourpath/?username=WT&password=123456&callback=myapp
其中invoking是URL Scheme 即[url scheme],com.hello是host,即[url host], yourpath是path,即[url path],username=WT&password=123456&callback=myapp是query,即[url query]。

二、调用自己开发的应用

1)在plist文件中,注册自定对外接口

CFBundleURLName(URL Identifier) A string containing the abstract name of the URL scheme. To ensure uniqueness, it is recommended that you specify a reverse-DNS style of identifier, for example, com.acme.myscheme.The string you specify is also used as a key in your app’s InfoPlist.strings file. The value of the key is the human-readable scheme name.

CFBundleURLSchemes(URL Schemes) An array of strings containing the URL scheme names—for example, http, mailto, tel, and sms.

可以设置多个(URL Schemes),设置成功后如下:


调用方的部分代码如下:

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. - (void)viewDidLoad  
  2. {  
  3.     [super viewDidLoad];  
  4.     // Do any additional setup after loading the view.  
  5.     CGRect rectTextView= CGRectMake(10.0f30.0f300.0f100.0f);  
  6.     self.textView = [[UITextView alloc] initWithFrame:rectTextView];  
  7.     [self.textView.layer setBorderColor:[UIColor lightGrayColor].CGColor];  
  8.     [self.textView.layer setBorderWidth:0.5f];  
  9.     [self.textView setText:@"username=WT&password=123456&callback=invoking"];  
  10.     [self.view addSubview:self.textView];  
  11.       
  12.     CGRect rect = CGRectMake(10.0f150.0f300.0f40.0f);  
  13.     UIButton *button = [UIButton buttonWithType:UIButtonTypeRoundedRect];  
  14.     button.frame = rect;  
  15.     [button setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];  
  16.     [button setTitle:@"Login" forState:UIControlStateNormal];  
  17.     [button setBackgroundColor:[UIColor blueColor]];  
  18.     [button addTarget:self action:@selector(handle:) forControlEvents:UIControlEventTouchUpInside];  
  19.     [button.layer setMasksToBounds:YES];  
  20.     [button.layer setCornerRadius:5.0f];  
  21.     [self.view addSubview:button];  
  22. }  
  23.   
  24. - (void)handle:(id)sender  
  25. {  
  26.       
  27.     NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:
  28. @"invoked://com.hello/path?%@"self.textView.text]];  
  29.     if ([[UIApplication sharedApplication] canOpenURL:url]) {  
  30.         [[UIApplication sharedApplication] openURL:url];  
  31.     } else {  
  32.         UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"message" 
  33. message:[NSString stringWithFormat:@"%@", url] 
  34. delegate:self cancelButtonTitle:@"确定" 
  35. otherButtonTitles:nil, nil nil];  
  36.         [alertView show];  
  37.     }  
  38. }  

被调用方的接收代码:

[objc] view plaincopy在CODE上查看代码片派生到我的代码片
  1. - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation  
  2. {  
  3.     NSLog(@"%@", url);  
  4.     if ([[url scheme] isEqualToString:@"invoked"]) {  
  5.         if ([[url host] isEqualToString:@"com.hello"]) {  
  6.             NSString *query = [url query];  
  7.             NSArray *array = [query componentsSeparatedByString:@"&"];  
  8.               
  9.             NSMutableDictionary *dic = [NSMutableDictionary dictionaryWithCapacity:10];  
  10.             for (NSString *item in array) {  
  11.                 NSArray *valueArray = [item componentsSeparatedByString:@"="];  
  12.                 [dic setValue:[valueArray objectAtIndex:1] forKey:[valueArray objectAtIndex:0]];  
  13.             }  
  14.             [self application:application didFinishLaunchingWithOptions:dic];  
  15.         }  
  16.         return YES;  
  17.     }  
  18.     return NO;  
  19. }  

同样,可以在传入参数中设置一些预留字段,以便以后扩展,要实现再能够回调回去,就可以加一个callback字段,如:callback=myapp 后面跟上自己应用的URL Scheme,再将执行完成的结果返回回去。代码处理和被调用方大致相同。

这篇关于iOS-应用间通信之自定义URL Schemes的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1108015

相关文章

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

C#使用SendMessage实现进程间通信的示例代码

《C#使用SendMessage实现进程间通信的示例代码》在软件开发中,进程间通信(IPC)是关键技术之一,C#通过调用WindowsAPI的SendMessage函数实现这一功能,本文将通过实例介绍... 目录第一章:SendMessage的底层原理揭秘第二章:构建跨进程通信桥梁2.1 定义通信协议2.2

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired