原来公司老的App用的微信SDK为1.8.2,并不需要配置Universal Link,
然后最近有需求需要新建一个APP,发现苹果官方从2020年中起,新建的App里就不允许使用UIWebView了,否则打包上传后无法在Apple Connect中显示,邮箱会收到如下的提示:
ITMS-90809: Deprecated API Usage - New apps that use UIWebView are no longer accepted. Instead, use WKWebView for improved security and reliability.
接下去检测项目中哪些代码或者插件使用了UIWebView,使用如下命令:
grep -r UIWebView .
发现微信SDK中使用了UIWebView,看来新的App已经无法使用1.8.2版本的微信SDK了,看了一下微信开放平台iOS相关文档,iOS的SDK从1.8.6.2开始移除UIWebView,也就是说,起码要升级到1.8.6.2,最新版本是1.9.1。
没办法,只能升级了,更新了项目中的SDK后发现初始化的方法变了:
// 原来
[WXApi registerApp: XXXX];
// 现在
[WXApi registerApp: XXXX universalLink: XXXX];
初始化需要Universal Link了,先不管他,直接设置空
[WXApi registerApp: XXXX universalLink: @""];
然后,App就无法拉起微信了。。
看来微信SDK现在一定要配置Universal Link了,我原来的理解是:Universal Link都是给需要从H5页面拉起App的需求用的,现在居然从我的App跳转微信App也需要配,没办法,他说要配那就只能配了。
Universal Link使用前提:
-有注册域名,并且支持https可通过 SSL 访问
-需要上传一个apple-app-site-association文件到域名根目录
-仅支持iOS 9及以上版本
-只支持真机调试
下面为Universal Link配置步骤
假设我们的域名为https://www.test.com
1、进入苹果开发者平台,登录账号,进入Identifiers,选择对应的App,进去后选中Associated Domains,然后Save。
2、如果你是手动建的Profile描述文件,记得要去Profiles中更新描述文件,老的已经不能用了。如果是XCode自动生成的,需要参考下图去XCode中的Build Setting中把Code Signing Entitlements内容清空,让XCode再自动生成一份描述文件。(手动生成无需清空)
注:由于删掉该记录会导致capabilities数据移除,需要重新添加capability。
3、在XCode工程中,添加Associated Domains,并将Universal Links域名上,这里的域名就为:applinks:www.test.com,不需要加任何前缀后缀
4、在info.plist中的LSApplicationQueriesSchemes里添加weixinULAPI
5、接下去配置apple-app-site-association文件,文件为json格式,但是要把.json后缀去掉。
在WWDC2019,苹果更新了apple-app-site-association文件的配置方法,推荐使用新写法,拥有更强的配置能力,参考链接。
放一张参考图和一些引用的解释,途中灰色的就为老的配置方法。
- apps 这个字段只有在 iOS 上有用,tvOS/macOS 这个字段可以忽略
- details 字段结构大幅度变化
- 以前是字典 appID 为 Key,现在是数组,并且支持 appIDs 这样的 key,可以一套配置适配多个 appID,大幅度减少工作量
- 新增 components 字段,可以进一步约束 Universal Link 的生效条件
- 可以通过 / 来配置支持的 path 格式条件
- 可以通过 # 来配置支持的锚点条件
- 可以通过 ? 来配置支持的字段条件
- exclude 是排除字段,符合这个条件的 Universal Link 不生效
我们这边可以这样配置,配置https://www.test.com/ios/后面的任意页面都适用Universal Link
{
"applinks": {
//"apps": [],
"details": [
{
//"appID": "TeamID.BundleID",
"appIDs": [ "TeamID.BundleID1", "TeamID.BundleID2" ],
//"paths": [ "/ios/*" ],
"components": [
{
"/": "/ios/*",
// "/": "*",如果要https://www.test.com下所有的页面都适用就这样配,但是推荐还是分一下路径,毕竟一个公司下可能会有多款App
"comment": "Matches any URL whose path starts with /ios/"
}
]
}
]
}
}
TeamID如何获取
6、配置后请后台管理人员把apple-app-site-association文件放在https://www.test.com根目录下,然后测试一下用浏览器打开https://www.test.com/apple-app-site-association,如果能显示文件内容或下载下来文件,则说明配置成功。
到这一步,真机重新运行App,然后真机打开Safari,浏览器输入https://www.test.com/ios/,页面虽然显示空白,但是往下拉一下,页面顶部已经显示了可以打开App了。
注:如果没效果,尝试删除一下App,重新运行。
如删除服务器上的apple-app-site-association文件,发现删除APP重新安装后,还是会显示顶部打开App,这个时候尝试删除App并重启手机。
如发现将apple-app-site-association文件重新放上服务器后,重新安装App后测试网页也不显示顶部栏,这时候尝试删除App并Clean一下Build,重新Build一下再安装。
7、去微信开发平台对应的应用中的iOS配置中配置一下Universal Link:https://apitest.mshchina.com/ios/
8、微信SDK初始化代码
[WXApi registerApp:微信AppID universalLink:@"https://apitest.mshchina.com/ios/"];
好了,再尝试调微信SDK,就可以在我们的App中拉起微信了。
遇到的坑
// URI scheme以及微信SDK处理iOS13以下版本的回调,走这个
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {
// 我们需要的判断跳转
return YES;
}
// Universal Links以及微信SDK处理iOS13以上版本的回调,走这个,两个方法都要适配
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray *restorableObjects))restorationHandler {
// 我们需要的判断跳转
return YES;
}