【iOS】应用间跳转:Universal Links 配置

前言

由于苹果iOS 13系统版本安全升级,微信对 openSDK 进行了适配。在微信openSDK 1.8.6版本之前,iOS APP使用的微信登录、分享、支付功能借助的是 URL scheme 的通信方式,在1.8.6版本后,则采用了 Universal Links 方式对调用openSDK的合法性进行校验。和 URL scheme 方式相比,Universal Links 方式操作更加安全便捷。如果你的app不做适配,那么有可能在分享的时候会出现 “未验证应用” 字样。

  • 微信开放平台移动应用 SDK 更新提醒

一、概念

Universal Links(通用链接),是苹果在iOS9之后,提供的一种“可通过传统HTTPS链接来跳转APP”的能力。该特性相较于传统的Custom URL Scheme方式,具备唯一、安全、私有和简单的优势。

二、应用场景

(1)第三方应用集成了友盟分享到QQ和微信的功能
(2)第三方应用分享了一个web页面到微信或QQ
(3)打开分享的web页面,点击上面的某一个按钮
(4)如果用户安装了该应用,直接打开应用根据web地址中的参数跳转到对应的页面
(5)如果用户没有安装应用,直接跳转到appStore

三、集成步骤

  1. 创建一个名字叫 apple-app-site-association 的 json 文件(注意:扩展名不需要),内容如下:
{
    "applinks":{
        "apps":[],
        "details":[
            {
                "appID":"TeamID.BundleID",
                "paths":["/qq_conn/{APPID}/*", "/wx_jst/*"]
            },
            {
                "appID": "ABCD12345.com.example.www",
                "paths": [ "*" ]
            }
        ]
    }
}

说明:
appID:格式为 TeamID.BundleID 形式。(打开苹果开发者官网,点击 Account,点击左边栏的 Membership,可以查找 TeamID)
paths:用于设置可以打开app的页面路径, 如果是 *,表示任何页面路径都可以用来打开 app。(注意:paths 路径是大小写敏感的)

  1. 将 apple-app-site-association 文件上传到自己的 https 服务器的 “.well-known” 或者根目录下。
  • 校验 apple-app-site-association 是否有效,可以通过苹果提供的工具验证:官方验证工具
  1. Xcode 中配置 Associated Domains
    打开 Xcode,选择 Signing & Capabilities。如右图所示,添加用于打开 app 的通用链接域名。
  • 假如我的域名是:https://www.domain.com ,即 applinks:www.domain.com , 域名必须是 https 格式。
  • 说明:这里配置的作用是,app 安装或更新后首次启动时,会从上面的域名请求 JSON 文件 apple-app-site-association(即从 https://www.domain.com/apple-app-site-association 下载这个文件)。
  1. 在 Xcode 中 info.plist 中配置参数,添加 weixinULAPIwechatweixin,如下图:
  1. 配置支持通用链接的交互(这里可以省略,如果你不需要任何交互)
    在 AppDelegate 里实现如下方法
#pragma mark - —————————————————— 处理从外部应用,跳转到本APP的回调 ——————————————————
#pragma mark - 通过 Universal Links 跳回本APP,会执行此回调
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray> * _Nullable))restorationHandler {
    // 如果是由 Universal Links 捕获进来的
    if ([userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
        NSLog(@"3.外部应用,跳回本APP:%@", userActivity.webpageURL);
    }
    
    // 处理通用链接:当 APP 被 UniversalLink 调起后
    BOOL result = [[UMSocialManager defaultManager] handleUniversalLink:userActivity options:nil];
    
    return result;
}

#pragma mark - 外部应用跳回本APP,会执行此回调(iOS9以后)
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary *)options API_AVAILABLE(ios(9.0)){
    // 微信登录:wx931ca155d7e13abd://oauth?code=041nZu0w3jnC6V2vXr1w3Tnb2L1nZu09&state=
    // 微信分享:wx931ca155d7e13abd://platformId=wechat
    // 微信支付:wx931ca155d7e13abd://pay/?returnKey=&ret=-2
    // QQ分享:QQ41E12968://response_from_qq?source=qq&source_scheme=mqqapi&error=0&version=1&sdkv=3.3.5_lite
    NSLog(@"[iOS9+]外部应用,跳回本APP:%@", url);
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
    if (!result) {
        // 其他如支付等SDK的回调
        return [Pingpp handleOpenURL:url withCompletion:nil];
    }

    return result;
}

// 外部应用跳回本APP,会执行此回调(iOS9以前)
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {
    NSLog(@"1.外部应用,跳回本APP:%@", url);
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation];
    if (!result) {
        // 其他如支付等SDK的回调
        return [Pingpp handleOpenURL:url withCompletion:nil];
    }
    return result;
}

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {
    NSLog(@"2.外部应用,跳回本APP:%@", url);
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
    if (!result) {
        // 其他如支付等SDK的回调
        return [Pingpp handleOpenURL:url withCompletion:nil];
    }
    return result;
}
  1. 前往微信开放平台在你的应用下设置 Universal Links


  2. 还有涉及QQ分享的,可以参考如下官方链接配置:QQ互联配置 UniversalLink

你可能感兴趣的:(【iOS】应用间跳转:Universal Links 配置)