鸿蒙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...

相关推荐
shr007_18 分钟前
flutter 鸿蒙
flutter·华为·harmonyos
鼓掌MVP4 小时前
【案例实战】多维度视角:鸿蒙2048游戏开发的深度分析与感悟
华为·ai编程·harmonyos·arkts·游戏开发·ability
安卓开发者4 小时前
鸿蒙Next Performance Analysis Kit:打造极致流畅的应用体验
华为·harmonyos
Devil枫4 小时前
【案例实战】HarmonyOS应用性能优化实战案例
华为·性能优化·harmonyos
猫林老师4 小时前
HarmonyOS线程模型与性能优化实战
数据库·分布式·harmonyos
一路阳光8515 小时前
鸿蒙生态发力,鸿蒙智行引领智能产业新征程
华为·harmonyos
一路阳光8517 小时前
开源鸿蒙5.0正式发布 底座及配套能力快速稳定成熟
华为·开源·harmonyos
HMSCore7 小时前
碰一碰,秒更新!游戏近场快传助力多人联机无缝组队
harmonyos
HarmonyOS_SDK7 小时前
碰一碰,秒更新!游戏近场快传助力多人联机无缝组队
harmonyos
鸿蒙小白龙8 小时前
基于 OpenHarmony 6.0 的智能充电桩技术方案与实现
能源·harmonyos·鸿蒙·鸿蒙系统·open harmony