鸿蒙应用安全编码专题系列之Web组件网络通信安全
头像 鸿蒙小助手 2026-05-25 14:52:49    发布
25 浏览 2 点赞 1 收藏

本原创文章帖发布在华为开发者联盟社区,欢迎开发者前往访问评论交流,更多与该内容相关讨论,请点击原帖查看:

鸿蒙应用安全编码专题文章汇总 | 华为开发者联盟


一、背景介绍

ArkWeb(方舟Web)提供的Web组件,是鸿蒙应用中用于加载并展示Web页面内容的核心组件,其应用场景覆盖多类开发需求,具体如下:

  1. 应用集成Web页面:应用可在界面中嵌入Web组件加载Web页面内容,有效降低开发成本,提升开发与运维效率。
  2. 浏览器网页浏览场景:浏览器类应用可通过Web组件打开第三方Web页面,支持无痕浏览、广告拦截等核心功能。
  3. 小程序场景:小程序宿主应用可借助Web组件实现小程序页面渲染、同层渲染、视频托管等核心功能。

当应用通过ArkWeb组件加载HTTPS协议URL(如

cke_148046.png

二、核心回调接口说明

两个回调接口声明如下,详情可参考:事件-Web-ArkTS 组件-ArkWeb(方舟Web)-应用框架 - 华为HarmonyOS开发者

2.1 onSslErrorEventReceive

onSslErrorEventReceive(callback: Callback<OnSslErrorEventReceiveEvent>)

通知用户加载资源时发生SSL错误,只支持主资源。

如果需要支持子资源,请使用OnSslErrorEvent接口。

说明

  • 主资源:浏览器加载网页的入口文件,通常是HTML文档。
  • 子资源:主资源中引用的依赖文件,由主资源解析过程中遇到特定标签时触发加载。
  • 应用程序需要调用handler.handleCancel()handler.handleConfirm()处理该回调,如果没有处理该回调则默认取消资源加载。handleConfirm()或者handleCancel()的行为可能会被记录下来,以便为将来的SSL错误做出响应。
  • 应用程序可以用于显示自定义错误页面或静默记录问题。

系统能力: SystemCapability.Web.Webview.Core

参数:

参数名类型必填说明
callbackCallback<OnSslErrorEventReceiveEvent>当网页收到SSL错误时触发。

2.2 onSslErrorEvent

onSslErrorEvent(callback: OnSslErrorEventCallback)

通知用户加载资源(主资源+子资源)时发生SSL错误,如果只想处理主资源的SSL错误,请用isMainFrame字段进行区分。

说明

  • 主资源:浏览器加载网页的入口文件,通常是HTML文档。
  • 子资源:主资源中引用的依赖文件,由主资源解析过程中遇到特定标签时触发加载。

系统能力: SystemCapability.Web.Webview.Core

参数:

展开

参数名类型必填说明
callbackOnSslErrorEventCallback通知用户加载资源时发生SSL错误。

三、mixedMode混合内容模式说明

Web组件加载HTTPS URL时,若页面资源、脚本中包含HTTP协议内容,会引入安全风险。ArkWeb提供mixedMode属性用于配置混合内容加载策略,具体配置参考官方文档:Enums-Web-ArkTS 组件-ArkWeb(方舟Web)-应用框架 - 华为HarmonyOS开发者

MixedMode

混合内容模式。

系统能力: SystemCapability.Web.Webview.Core

名称说明
All0宽松模式:允许加载HTTP和HTTPS混合内容。所有不安全的内容都可以被加载。
Compatible1兼容模式:混合内容兼容性模式,部分不安全的内容可能被加载。
None2严格模式:不允许加载HTTP和HTTPS混合内容。

四、不安全实现及风险分析

HTTPS协议的安全性核心依赖证书链校验、安全TLS协议及加密算法。以下为两种典型的不安全实现方式,均会引入中间人攻击风险,导致通信数据被劫持、篡改或泄露。

4.1 SSL错误回调处理不当

收到SSL错误通知时,若直接忽略错误并调用event.handler.handleConfirm()继续加载,会绕过证书校验机制,直接引入中间人攻击风险。

不安全示例代码

Web({ src: 'https://xxx.example.com', controller: this.controller })
  .onSslErrorEventReceive((event) => {
    event.handler.handleConfirm(); // 直接忽略SSL错误,继续加载,存在安全风险
  })

正确实现方式:不实现onSslErrorEventReceiveonSslErrorEvent回调(系统默认取消资源加载);或在回调中调用event.handler.handleCancel()主动取消加载,阻断不安全连接。

正确示例代码

Web({ src: 'https://xxx.example.com', controller: this.controller })
  .onSslErrorEventReceive((event) => {
    event.handler.handleCancel(); // 收到SSL错误,取消加载,规避安全风险
  })

4.2 mixedMode配置不当

mixedMode配置为MixedMode.All(宽松模式),允许加载HTTP与HTTPS混合内容,会导致HTTPS通信的安全性被破坏,引入中间人攻击风险。

不安全示例代码


Web({ src: 'https://xxx.example.com', controller: this.controller })
  .onSslErrorEventReceive((event) => {
    event.handler.handleCancel();
  })
  .mixedMode(MixedMode.All) // 宽松模式,允许混合内容加载,存在安全风险

正确实现方式:将mixedMode配置为MixedMode.None(严格模式),同时推动服务器将所有HTTP资源链接修改为HTTPS协议,规避混合内容安全风险。

正确示例代码

Web({ src: 'https://xxx.example.com', controller: this.controller })
  .onSslErrorEventReceive((event) => {
    event.handler.handleCancel();
  })
  .mixedMode(MixedMode.None) // 严格模式,禁止混合内容加载,保障通信安全

五、安全建议

基于上述分析,为保障Web组件加载URL过程中的网络通信安全,结合鸿蒙应用开发规范,提出以下安全建议:

  1. SSL错误回调处理:禁止在onSslErrorEventReceive或onSslErrorEvent回调中调用event.handler.handleConfirm(),建议使用系统默认配置(不实现回调),或主动调用handleCancel()取消加载。
  2. mixedMode配置:禁止将mixedMode配置为MixedMode.All,建议使用系统默认配置,或显式配置为MixedMode.None,从根源规避混合内容安全风险。

六、参考文档

  • ArkWeb Web组件事件说明:事件-Web-ArkTS 组件-ArkWeb(方舟Web)-应用框架 - 华为HarmonyOS开发者
  • ArkWeb Web组件mixedMode配置:Enums-Web-ArkTS 组件-ArkWeb(方舟Web)-应用框架 - 华为HarmonyOS开发者

其他鸿蒙应用安全编码专题文章请参考:

https://developer.huawei.com/consumer/cn/blog//topic/03207416677214221?ha_source=zxqy-IT&ha_sourceId=89000468



©本站发布的所有内容,包括但不限于文字、图片、音频、视频、图表、标志、标识、广告、商标、商号、域名、软件、程序等,除特别标明外,均来源于网络或用户投稿,版权归原作者或原出处所有。我们致力于保护原作者版权,若涉及版权问题,请及时联系我们进行处理。
分类
HarmonyOS
头像

鸿蒙小助手

致力于为鸿蒙开发者谋福利

1061

帖子

7

提问

13569

粉丝

关注
热门推荐
地址:北京市朝阳区北三环东路三元桥曙光西里甲1号第三置业A座1508室 商务内容合作QQ:2291221 电话:13391790444或(010)62178877
版权所有:电脑商情信息服务集团 北京赢邦策略咨询有限责任公司
声明:本媒体部分图片、文章来源于网络,版权归原作者所有,我司致力于保护作者版权,如有侵权,请与我司联系删除

京ICP备:2022009079号-2

京公网安备:11010502051901号

ICP证:京B2-20230255