iOS应用之间的调用


引言:
项目需求不同应用之间的相互调用,类似分享到微信、QQ、新浪微博应用之间的调用等,废话不多说,记录一下,心得体验!


一、 Url Scheme
在iOS中应用之间的调用需要设置 Url Scheme,例如:如果“应用One”调用“应用Two”,那么应用Two需要设置自己的 Url Scheme,并且“应用One”需要知道“应用Two”的 Url Scheme才可以调用应用Two。

1.自定义 Url Scheme

  • info.plist
    利用info.plist自定义,如图所示:
iOS应用之间的调用_第1张图片
1.自定义 Url Scheme.png

Url Scheme可以随意自定义,也就是你喜欢怎样就怎样,O(∩_∩)O~,太嘚瑟了,不过呢,利用bundle identifier是可以的,亲测OK。(PS:此处有个取巧的地方,后面会介绍)。

  • 简便自定义
    其实也是在info.plist中,Xcode为广大开发者提供了简便工程配置,如图红色框中所示:
iOS应用之间的调用_第2张图片
2.自定义 Url Scheme.png

其实是相同的设置,只不过Xcode提供了更加直观的方式。

  • XML 自定义
    将info.plist显示为XML格式,进行更改,对于熟悉XML格式的同学,比较适合。

iOS应用之间的调用_第3张图片
3.自定义 Url Scheme.png

如何图红框内的数据结构,其实就是前两种方法的数据结构。
二、应用之间调用的实现
上面自定义的Url Scheme 都是在应用Two内设置的,下面应用One需要其Url Scheme 并调起应用Two。应用One内的代码非常简单,此处说明一下,调用其他应用就是打开某个Url,格式为:
@"自定义Url Scheme://"
协议头为你需要调用的应用的自定义的Url Scheme,协议内容可以为空。
在应用One控制器内实现了简单的按钮的点击跳转效果,代码如下:

- (IBAction)jumpApplication {
    
    NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@"%@://",
[[[[NSBundle mainBundle] infoDictionary] objectForKey:@"LSApplicationQueriesSchemes"] lastObject]]];
    if ([[UIApplication sharedApplication] canOpenURL:url]) {
        [[UIApplication sharedApplication] openURL:url];
    }
    
}

上述代码中,@“LSApplicationQueriesSchemes” 是在iOS9中才需要的,iOS9开始应用之间的调用,需要设置白名单,也就是将应用Two自定义的Url Scheme 添加到应用One中的白名单中,@“LSApplicationQueriesSchemes”所对应的数组内。添加方法类似添加分享到微信、QQ等的白名单,这里就不赘述了。iOS9在首次调用的时候会提示用户是否打开XX应用。

iOS应用之间的调用_第4张图片
4.open application.png

点击Open就可以调转到应用Two了

iOS应用之间的调用_第5张图片
5.跳转到应用Two.png

当然这还设置到一个返回前个应用的操作,iOS9提供了箭头所指的返回方式,Coder也可以自定义!
三、反跳转
反跳转原理同跳转!
首先,在应用One跳转到应用Two时,不管应用Two是否正在运行,都会调用应用Two的代理方法。

iOS应用之间的调用_第6张图片
6.应用Two的代理方法.png

注意上面的红框内的方法在iOS9开始已经废弃了,统一使用下面红框内的代理方法。
这里解释一下之前为什么使用bundle Identifier作为自定义的Url Scheme:

  • 下面的代理方法中的options参数是个字典,字典中利用@"UIApplicationOpenURLOptionsSourceApplicationKey"
    键可以取到应用One的bundle identifier,利用相同的原理在跳回前个应用。
  • Url Scheme需有唯一性,否则应用在跳转的时候不知到底要跳转哪个应用,而bundle identifier具有此性质。
  • 下面的代理方法中的url也可以拿到前个应用的Url Scheme
    例如:
    在应用One中openUrl时添加协议体,将应用One的Url Scheme传递过来,如:@“com.neunn.ApplicationTwo://com.neunn.ApplicationOne”
    但是这的需要截取字符串拿到应用One的Url Scheme,比较麻烦,所以取巧使用了bundle Identifier。
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary *)options{

    NSUserDefaults *userDefault = [NSUserDefaults standardUserDefaults];
    [userDefault setObject:[options objectForKey:@"UIApplicationOpenURLOptionsSourceApplicationKey"] forKey:@"key"];
    [userDefault synchronize];
    return YES;
}

这样在应用Two的控制器内实现的反跳转代码,如下:

- (IBAction)jumpBack {
    
    NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@"%@://",[[NSUserDefaults standardUserDefaults] objectForKey:@"key"]]];
//    if ([[UIApplication sharedApplication] canOpenURL:url]) {
        [[UIApplication sharedApplication] openURL:url];
//    }
    
}

取出在代理方法内存储的Url Scheme拼接为符合格式的Url,Done!
但是这里需要注意的是:
iOS9中如果使用上述代码中注释的
[UIApplication sharedApplication] canOpenURL:url]
判断是否可以打开的话,还是会提示设置应用Two的白名单,才可以打开应用One,这里没必要判断,直接打开就可以了。
当然你也可以判断失败后,代码修改info.plist文件已达到设置白名单,可以跳转的目的。
:iOS9之后在没有添加白名单的情况下,并不影响[UIApplication sharedApplication] openURL:url]的使用。

你可能感兴趣的:(iOS应用之间的调用)