harmony 鸿蒙拉起指定应用概述

  • 2025-06-12
  • 浏览 (3)

拉起指定应用概述

本章节主要介绍如何通过应用链接跳转的方式拉起指定应用。

说明:

从API 12开始,已不再推荐三方应用使用指定Ability方式(即显式Want)拉起其他应用。关于如何从指定Ability方式切换到指定应用链接方式,详见显式Want跳转切换应用链接跳转适配指导

应用链接

应用链接是指可以将用户引导至应用内特定位置或相关网页的URL,常见的格式如下。更多关于应用链接格式与字段含义的说明,详见应用链接说明

scheme://host[:port]/path

运作机制

  1. 目标应用在配置文件中注册自己的URL,并对外提供URL。
  2. 拉起方应用在跳转接口中传入目标应用的URL等信息。
  3. 系统接收到URL等相关信息,会寻找对应匹配项,并跳转至目标应用。

应用链接分类

按照应用链接的scheme以及校验机制的不同,可以分为Deep Linking与App Linking两种方式。

  • Deep Linking:是一种通过链接跳转至应用特定页面的技术,其特点是支持开发者定义任意形式的scheme。由于缺乏域名校验机制,容易被其他应用所仿冒。

  • App Linking:其限定了scheme必须为https,同时通过增加域名校验机制,可以从已匹配到的应用中筛选过滤出目标应用,消除应用查询和定位中产生的歧义,直达受信的目标应用。

相比Deep Linking,App Linking具有更高的安全性和可靠性,用户体验更佳。推荐开发者将App Linking作为首选方案。

类型 App Linking(推荐) Deep Linking
实现方案 目标应用需要在module.json5中声明应用链接;同时需要向系统注册域名并通过域名认证。 目标应用需要在module.json5中声明应用链接。
链接格式 scheme必须为https。 scheme可以自定义。通常不为https、http、file,否则会拉起默认的系统浏览器。
是否可用于分享或直接在网页中访问 可以 不可以,需在代码中调用。
是否可以直接拉起目标应用 可以 可以,但不推荐使用,存在被仿冒风险。

Deep Linking与App Linking均可以使用openLink接口实现,不同条件下的跳转效果如下。

说明:

该接口中的appLinkingOnly字段表示是否必须以App Linking的方式启动UIAbility,默认为false。appLinkingOnly为true一般只用于浏览器等应用。

应用链接类型 App Linking(推荐) Deep Linking
appLinkingOnly为false且目标应用已安装 直接跳转打开目标应用。 跳转目标应用(如果有多个符合条件的应用时,展示应用选择弹框)。
appLinkingOnly为false且目标应用未安装 跳转默认浏览器打开网页。 返回失败,系统不跳转,由应用自行处理;当前会展示“链接无法打开”弹框。
appLinkingOnly为true且目标应用已安装 直接跳转打开目标应用。 返回失败,系统不跳转,由应用自行处理。
appLinkingOnly为true且目标应用未安装 返回失败,系统不跳转由应用自行处理。 返回失败,系统不跳转,由应用自行处理。

你可能感兴趣的鸿蒙文章

harmony 鸿蒙Ability Kit(程序框架服务)

harmony 鸿蒙获取应用异常退出原因

harmony 鸿蒙UIAbility备份恢复

harmony 鸿蒙使用显式Want启动应用组件

harmony 鸿蒙Ability Kit简介

harmony 鸿蒙AbilityStage组件容器

harmony 鸿蒙访问DataAbility

harmony 鸿蒙FA模型访问Stage模型DataShareExtensionAbility

harmony 鸿蒙常见action与entities(不推荐使用)

harmony 鸿蒙API切换概述

0  赞