前言
由于苹果iOS 13系统版本安全升级,微信对 openSDK 进行了适配。在微信openSDK 1.8.6版本之前,iOS APP使用的微信登录、分享、支付功能借助的是
URL scheme
的通信方式,在1.8.6版本后,则采用了Universal Links
方式对调用openSDK的合法性进行校验。和 URL scheme 方式相比,Universal Links 方式操作更加安全便捷。如果你的app不做适配,那么有可能在分享的时候会出现 “未验证应用” 字样。
一、概念
Universal Links(通用链接),是苹果在iOS9之后,提供的一种“可通过传统HTTPS链接来跳转APP”的能力。该特性相较于传统的Custom URL Scheme方式,具备唯一、安全、私有和简单的优势。
二、应用场景
(1)第三方应用集成了友盟分享到QQ和微信的功能
(2)第三方应用分享了一个web页面到微信或QQ
(3)打开分享的web页面,点击上面的某一个按钮
(4)如果用户安装了该应用,直接打开应用根据web地址中的参数跳转到对应的页面
(5)如果用户没有安装应用,直接跳转到appStore
三、集成步骤
- 创建一个名字叫
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 路径是大小写敏感的)
- 将 apple-app-site-association 文件上传到自己的 https 服务器的 “.well-known” 或者根目录下。
- 校验 apple-app-site-association 是否有效,可以通过苹果提供的工具验证:官方验证工具
- 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 下载这个文件)。
- 在 Xcode 中 info.plist 中配置参数,添加
weixinULAPI
、wechat
、weixin
,如下图:
- 配置支持通用链接的交互(这里可以省略,如果你不需要任何交互)
在 AppDelegate 里实现如下方法
#pragma mark - —————————————————— 处理从外部应用,跳转到本APP的回调 ——————————————————
#pragma mark - 通过 Universal Links 跳回本APP,会执行此回调
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray<id<UIUserActivityRestoring>> * _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<UIApplicationOpenURLOptionsKey,id> *)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;
}
-
前往微信开放平台在你的应用下设置 Universal Links
还有涉及QQ分享的,可以参考如下官方链接配置:QQ互联配置 UniversalLink