鸿蒙AppLink即iOS的通用跳转(Universal Link)的实现

写在前面

鸿蒙作为一个新的系统,借鉴了很多其他系统的实现方案,并做了一些更加高效的提升,虽然目前大部分公司在开发的时候都是让安卓或者web的同事来开发,但我觉得之前有iOS开发经验的同学,更能理解鸿蒙系统的一些实现设计和方案,比如:应用内支付等等,包括这次分享的Applink,其实现效果和iOS的通用跳转基本是一致的。

适用场景

通用跳转的适用场景对于大部分公司的App来说,都是分享H5页面到微信或者用系统浏览器打开之后,可以直接通过点击按钮,打开对应的App,并可以携带对应的参数,达到一个H5和App的互通。在鸿蒙里,虽然当时开发的时候还没有微信,但是也可以通过系统浏览器来模拟这个跳转。

开发前准备工作

  1. 获取Associated Domains,这个是配置在iOS工程里的,也就是我们之前iOS已经实现的通用链接的域名,我当然默认你们已经有了。获取的位置如下图,看配置就能发现,可以配置多个域名,方便我们实际应用时进行区分。
  1. 创建域名配置文件applinking.json,内容如下:
{ 复制代码
         "applinking": {
           "apps": [
             {
    		/// 在应用后台查看自己应用的APP ID
               "appIdentifier": "1234567"
             }
           ]
         }
        } 
  1. 将这个配置文件,放到第一步中,我们所支持的domain下。举个例子,我们支持的domain是:card.test.io,那么我们就要将配置文件放到:card.test.io/.well-known... 这一步让公司的运维来操作就行,你发给他配置文件,并且告诉他需要访问到的路径就行。
  2. 打开华为的应用后台,找到增长-App Linking菜单,按照下图创建应用链接即可。举个例子,我们支持的domain是:card.test.io,那么新建的域名就是:card.test.io。这一步创建成功后,华为会去校验你创建的域名下是否能访问到applinking.json文件,正常能访问,状态就会变为成功。

鸿蒙项目配置

鸿蒙项目中的配置,参考文档进行配置即可,主要是对module.json5文件的skills进行修改。我这里提供一份我自己的配置供大家参考。

因为我们自己的应用除了要支持App Linking外,还支持音频的后台播放,这部分配置和文档中的有些许差别,不过没关系,仅供参考,配置的module.json5文件是我们EntryAbilitymodule.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的版本还没有上线的缘故,反正目前上架之后,在浏览器里点击打开的时候,已经没有这个提示了,所以遇到这个提示,大家也不用担心。

参考文档

developer.huawei.com/consumer/cn...

相关推荐
枫叶丹43 小时前
【HarmonyOS之旅】HarmonyOS开发基础知识(三)
华为od·华为·华为云·harmonyos
SoraLuna8 小时前
「Mac畅玩鸿蒙与硬件47」UI互动应用篇24 - 虚拟音乐控制台
开发语言·macos·ui·华为·harmonyos
AORO_BEIDOU11 小时前
单北斗+鸿蒙系统+国产芯片,遨游防爆手机自主可控“三保险”
华为·智能手机·harmonyos
博览鸿蒙13 小时前
鸿蒙操作系统(HarmonyOS)的应用开发入门
华为·harmonyos
Damon小智20 小时前
HarmonyOS NEXT 技术实践-基于基础视觉服务的多目标识别
华为·harmonyos
爱笑的眼睛112 天前
uniapp 极速上手鸿蒙开发
华为·uni-app·harmonyos
K.P2 天前
鸿蒙元服务从0到上架【第三篇】(第二招有捷径)
华为·harmonyos·鸿蒙系统
K.P2 天前
鸿蒙元服务从0到上架【第二篇】
华为·harmonyos·鸿蒙系统
敲代码的小强2 天前
Flutter项目兼容鸿蒙Next系统
flutter·华为·harmonyos
程序猿会指北2 天前
纯血鸿蒙APP实战开发——Text实现部分文本高亮和超链接样式
移动开发·harmonyos·arkts·openharmony·arkui·组件化·鸿蒙开发