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

相关文章

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

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

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

从基础到高阶详解Python多态实战应用指南

《从基础到高阶详解Python多态实战应用指南》这篇文章主要从基础到高阶为大家详细介绍Python中多态的相关应用与技巧,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、多态的本质:python的“鸭子类型”哲学二、多态的三大实战场景场景1:数据处理管道——统一处理不同数据格式

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

C语言自定义类型之联合和枚举解读

《C语言自定义类型之联合和枚举解读》联合体共享内存,大小由最大成员决定,遵循对齐规则;枚举类型列举可能值,提升可读性和类型安全性,两者在C语言中用于优化内存和程序效率... 目录一、联合体1.1 联合体类型的声明1.2 联合体的特点1.2.1 特点11.2.2 特点21.2.3 特点31.3 联合体的大小1