美文网首页APP & program
iOS app之间跳转

iOS app之间跳转

作者: 万年老参 | 来源:发表于2023-12-14 11:13 被阅读0次

    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。

    相关文章

      网友评论

        本文标题:iOS app之间跳转

        本文链接:https://www.haomeiwen.com/subject/zoboydtx.html