iOS app之间跳转
app之间的跳转有两种方式:URL Scheme和Universal Link。除了app之间跳转,扫码打开app或H5页面跳转app,或NFC打开app也是通过这两种方式。
URL Scheme(配置这个,可以让别的app跳转到我们app的)
urlScheme可以理解为app名+白名单模式。
一,Scheme设置
Scheme规则:
1.一般用翻转BundleID的方式来保证唯一性,
2.如果一台设备多个APP使用了同一Scheme,则先安装的会生效。
(以下两种方式等效):
第一种.png 第二种.png
设置好后可以在safari浏览器输入‘SchemeName’://,若能跳转则表示设置成功。(比如my://)
此时设置好了app的Scheme,其它app可通过此字符串跳转到我们的app
同时如果知道别的app的Scheme也可以用以下代码跳转到目标app
跳转代码:
UIApplication *app = [UIApplication sharedApplication];
// 2.创建要打开的应用程序的URL
NSURL *url = [NSURL URLWithString:@"otherApp://"];
[app openURL:url options:@{UIApplicationOpenURLOptionsSourceApplicationKey : @YES} completionHandler:nil];
二,白名单配置,配置了白名单的应用,我们可以在跳转前判断是否已安装。
先看以下代码:
UIApplication *app = [UIApplication sharedApplication];
// 2.创建要打开的应用程序的URL
NSURL *url = [NSURL URLWithString:@"otherApp://"];
//也可以添加参数以便在目标App内进行处理
//NSURL *url = [NSURL URLWithString:@"otherApp://printLog"];
// 3.判断是否可以打开另一个应用
if ([app canOpenURL:url]) {
// 能,就打开
[app openURL:url options:@{UIApplicationOpenURLOptionsSourceApplicationKey : @YES} completionHandler:nil];
} else {
NSLog(@"打开应用失败");
[app openURL:url options:@{UIApplicationOpenURLOptionsSourceApplicationKey : @YES} completionHandler:nil];
}
注意:canOpenURL返回no时,并不一定是无法跳转。有以下两种可能:
1,目标app已安装,但未添加进白名单,仍旧可跳转,输出:
-canOpenURL: failed for URL: "otherApp://" - error: "This app is not allowed to query for scheme otherApp"、
打开应用失败
2,目标app未安装,则输出:
URL: "otherApp://" - error: "The operation couldn’t be completed. (OSStatus error -10814.)"
白名单配置方式(最多50个):
item的值对应目标app的Scheme。
三,外部通过URL Scheme跳入,获取附加参数:
若使用了SceneDelegate:
在SceneDelegate.m中:
- (void)scene:(UIScene *)scene openURLContexts:(NSSet<UIOpenURLContext *> *)URLContexts {
if (@available(iOS 13.0, *)) {
UIOpenURLContext *a = URLContexts.allObjects.firstObject;
if ([a.URL.absoluteString containsString:@"my://bbb"]) {
//执行对应代码
}
}
}
若不使用SceneDelegate,则在在AppDelegate中实现以下方法即可
//此代理方法可以获取到跳转过来的URL,并
-(BOOL)application:(UIApplication *)application openURL:(NSURL * _Nonnull)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> * _Nonnull)options
{
NSString *urlString = [url absoluteString];
//2.判断地址中包含的信息为bbb则执行对应操作。
if ([urlString hasPrefix:@"my://bbb"])
{
NSLog(@"123123");
[[NSUserDefaults standardUserDefaults] setObject:@"222" forKey:@"valueee"];
}
return YES;
}
niversal Link
url scheme有两个比较大的缺陷,第一每次唤起app时都会有弹框,并且当手机没有安装app时,会有错误提示。第二,app的scheme是由开发者自己填写的,不可避免有多个app的scheme重复问题。
niversal Link(通用链接)是一个HTTPS的链接,通过打开一个链接来跳转app,能实现web-app无缝衔接,并且支持手机未安装时,展示web页面,引导用户下载。
原理:在第一次安装APP的时候,iOS系统会去指定的路径(这个路径是后面需要后端开发人员提供的)下载apple-app-site-association文件。通过这个文件,iOS系统就会知道哪些URL是Universal Links,哪些不是Universal Links。从而我们指定的路径可以发生跳转。这个apple-app-site-association文件需要开发者去创建和放到一个苹果可以访问的服务器上。这个过程在XCode调试的时候也会发生,(testFlight安装的app还未经测试)
niversal Link实现要求:
- 只支持 iOS 9+
- 拥有一个域名
- 通过 SSL 访问域名(即支持HTTPS)
- 上传一个 JSON 文件到域名下(名为 apple-app-site-association 的json格式文件)
niversal Link的配置分为三部分,
1:Apple Developer网站配置、
2:服务器资源配置(apple-app-site-association文件创建和存放)
3:Xcode配置、
一,Apple Developer网站配置
项目的App ID 需要开通Associated Domains。在Apple Developer网站找到对应app的Identifiers,勾选以下权限
image.png
进行此步骤后,需要重新生成Profiles文件,直接删掉老的,xcode会完成Profiles的配置。
二、服务器资源配置(apple-app-site-association文件创建和存放)
apple-app-site-association文件:
纯文本文件,json格式,大小128kb以内,内容如下:
{"applinks": {
"apps": [],
"details": [
{
"appID": "团队ID.软件BundleID/APP ID",
"paths": ["限制的路径节点名,没有限制就填*"]
}
]
}
}
details数组可以添加多个app,比如:
{ "applinks": {
"apps": [],
"details": [ {
"appID": "9JA89QQLNQ.com.apple.wwdc",
"paths": [ "/wwdc/news/", "/videos/wwdc/2015*"]
}, {
"appID":"ABCD1234.com.yhd.kk",
"paths": [ "/qq_conn/222222/*" ]
} , {
"appID":"ABCD1234.com.abcde.kk",
"paths": ["*"]
}]
}
}
一个apple-app-site-association可以支持在同一地址下不同路径唤起不同app。
apple-app-site-association文件的存放
这个文件创建好之后,交给后端人员。让他们把这个文件放到他们想放的url的根目录下(这个URL在配置XCode会用到)。
【验证】:验证后端是否正确放置,就在浏览器输入这个后端提供的存放地址,会直接下载apple-app-site-association文件。如果没有下载到这个软件,说明服务器配置不对。
【注意】:我在验证过程中下载下来的apple-app-site-association文件名字不是“apple-app-site-association”,但是这没有影响。只要放到服务器的名字是apple-app-site-association就行。
三,Xcode配置
目的就是在app内声明,iOS在安装此app的时候告诉系统:(用户安装我这个app的话,要记的去这个地址来下载apple-app-site-association文件哦~)
Domains 的填充内容是以applinks:域名 的格式即可,如下图:
29a0abbd4bce4c5c9f4284515f627113.png
可能的问题:
Xcode自动管理的Profiles没有附带Associated Domains,导致app安装到手机上时,系统没有去对应地址下载apple-app-site-association文件。导致无法唤起app。