写在前面
鸿蒙作为一个新的系统,借鉴了很多其他系统的实现方案,并做了一些更加高效的提升,虽然目前大部分公司在开发的时候都是让安卓或者web的同事来开发,但我觉得之前有iOS开发经验的同学,更能理解鸿蒙系统的一些实现设计和方案,比如:应用内支付等等,包括这次分享的Applink,其实现效果和iOS的通用跳转基本是一致的。
适用场景
通用跳转的适用场景对于大部分公司的App来说,都是分享H5页面到微信或者用系统浏览器打开之后,可以直接通过点击按钮,打开对应的App,并可以携带对应的参数,达到一个H5和App的互通。在鸿蒙里,虽然当时开发的时候还没有微信,但是也可以通过系统浏览器来模拟这个跳转。
开发前准备工作
- 获取Associated Domains,这个是配置在iOS工程里的,也就是我们之前iOS已经实现的通用链接的域名,我当然默认你们已经有了。获取的位置如下图,看配置就能发现,可以配置多个域名,方便我们实际应用时进行区分。
- 创建域名配置文件
applinking.json
,内容如下:
{
"applinking": {
"apps": [
{
/// 在应用后台查看自己应用的APP ID
"appIdentifier": "1234567"
}
]
}
}
- 将这个配置文件,放到第一步中,我们所支持的domain下。举个例子,我们支持的domain是:
card.test.io
,那么我们就要将配置文件放到:card.test.io/.well-known... 这一步让公司的运维来操作就行,你发给他配置文件,并且告诉他需要访问到的路径就行。 - 打开华为的应用后台,找到增长-App Linking菜单,按照下图创建应用链接即可。举个例子,我们支持的domain是:
card.test.io
,那么新建的域名就是:card.test.io。这一步创建成功后,华为会去校验你创建的域名下是否能访问到applinking.json
文件,正常能访问,状态就会变为成功。
鸿蒙项目配置
鸿蒙项目中的配置,参考文档进行配置即可,主要是对module.json5
文件的skills
进行修改。我这里提供一份我自己的配置供大家参考。
因为我们自己的应用除了要支持App Linking外,还支持音频的后台播放,这部分配置和文档中的有些许差别,不过没关系,仅供参考,配置的module.json5
文件是我们EntryAbility
的module.json5
文件,大部分的内容都是固定的,需要修改的部分,一眼就能看到。
json
"skills": [
{
"entities": [
"entity.system.home"
],
"actions": [
"action.system.home"
],
},
{
"domainVerify": true,
"entities": [
"entity.system.browsable",
"entity.system.home"
],
"actions": [
"ohos.want.action.viewData",
"action.system.home"
],
"uris": [
{
"scheme": "https",
"host": "deeplink.test.io"
},
{
"scheme": "https",
"host": "card.test.io"
},
{
"scheme": "https",
"host": "card.test.com"
},
{
"scheme": "https",
"host": "deeplink.test.com"
}
]
}
]
处理App Linking的跳转事件
- 通过App Linking冷启动App
- 通过App Linking热启动App
在EntryAbility.ets
中实现对应的方法,就可以获取到完整的App Linking地址,根据实际情况进行跳转即可。
scss
/// 冷启动
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
let uri = want?.uri
if (uri) {
// 从链接中解析query参数,拿到参数后,开发者可根据自己的业务需求进行后续的处理。
}
}
/// 热启动
onNewWant(want: Want, launchParam: AbilityConstant.LaunchParam) {
let uri = want?.uri
if (uri) {
// 从链接中解析query参数,拿到参数后,开发者可根据自己的业务需求进行后续的处理。
}
}
网页部分
H5部分在点击跳转时,需要和iOS设备类型的实现方式一致,即简单的实现打开链接即可,类似:
window.location='<https://deeplink/xxxx'
最后
在实现的过程中,遇到过在浏览器点击链接打开的时候,会提示:无法打开此链接,可前往应用市场查找更多应用的提示。但是还是打开了目标App,和华为的人反馈说后续会修复,不知道是因为当时支持App Linking的版本还没有上线的缘故,反正目前上架之后,在浏览器里点击打开的时候,已经没有这个提示了,所以遇到这个提示,大家也不用担心。