鸿蒙HAR对外发布安全流程

本文作者:杉木@涂鸦智能安全实验室

了解鸿蒙HAR

构建HAR-配置构建流程-构建应用 - 华为HarmonyOS开发者

字节码HAR包中包含的是编译后的abc字节码,当字节码HAR被其他应用模块(HAP/HSP)依赖时,执行应用模块的编译构建,不需要再对依赖的HAR进行语法检查和编译等操作,相比源码HAR,可以有效提升应用模块的编译构建效率,提高安全性,降低代码泄漏的风险。

HAR包的安装和使用

安装 HAR 包到你的项目中,主要有两种方式:从远程仓库安装和从本地安装。

  • 从远程仓库安装(以官方三方库中心仓为例)

    1. 命令行一键安装 :在 DevEco Studio 的 Terminal 中,进入你的项目目录(通常是 entry目录),执行以下命令。这会自动下载最新的 HAR 包并更新依赖配置。

      bash 复制代码
      ohpm install @ohos/[HAR包名]
    2. 手动配置依赖 :在项目的 oh-package.json5文件中的 dependencies字段添加依赖信息,然后执行 ohpm install

      json 复制代码
      "dependencies": {
        "@ohos/lottie": "^2.0.9"// 格式通常为 "包名": "版本号"}
  • 从本地安装

    1. 依赖本地模块 :如果你的 HAR 包是项目内的另一个 Library 模块,可以在 oh-package.json5中配置。

      json 复制代码
      "dependencies": {
        "@ohos/mylibrary": "file:../library"// "file:"后跟模块的相对路径}
    2. 依赖本地 HAR 文件 :如果你有现成的 .har文件,可以将其放入项目下的一个目录(如 libs),然后在 oh-package.json5中配置。完成上述配置后,同样需要在 Terminal 中执行 ohpm install 命令来完成安装。安装成功后,依赖项会存储在项目的 oh_modules目录下。

      json 复制代码
      "dependencies": {
        "@ohos/log_fishing": "file:./libs/logfishing.har"
      }

关于HAR、HAP、HSP

特性 HAR (Harmony Archive) HAP (Harmony Ability Package) HSP (Harmony Shared Package)
全称与本质 鸿蒙静态共享包 鸿蒙能力包,应用部署包 鸿蒙共享包,动态共享包
主要作用 代码和资源的静态共享与复用 应用的安装和运行单元 代码和资源的动态共享,减少体积
编译行为 编译时被复制到依赖它的HAP中 独立编译或依赖HAR/HSP 编译时不复制,运行时动态依赖
代码共享方式 源码级共享,副本式(多份拷贝) 不直接用于共享 二进制级共享,单例式(一份实例)
是否可以独立运行

ohpm-repo私仓搭建

个人或公司可以上传编译后的HAR到ohpm仓库中,也可以自己搭建私仓,官方提供了私仓搭建工具,具体参考:

快速开始-ohpm-repo私仓搭建工具-模块管理-工程创建-开发环境搭建 - 华为HarmonyOS开发者

其中需要注意相关安全配置:

安全配置指南-ohpm-repo私仓搭建工具-模块管理-工程创建-开发环境搭建 - 华为HarmonyOS开发者

HAR对外发布安全流程

其实看到这里,HAR可以类比Android的SDK或者so库,只不过HAR没有c的安全编译配置,只有混淆配置,因此HAR对外发布因在安全编译配置中默认开启混淆设置,以增加逆向工程难度,防止源代码泄露风险;

且遵循代码安全开发规范,不要硬编码敏感信息到代码中;

漏洞悬赏计划:涂鸦智能安全响应中心(https://src.tuya.com)欢迎白帽子来探索。

相关推荐
木咺吟5 小时前
鸿蒙原生应用实战(一):从零搭建快递追踪App——项目初始化与工程架构详解
华为·harmonyos
坚果派·白晓明7 小时前
【鸿蒙PC】SDL3 移植:AtomCode Skills 4 步速通多媒体库适配
c++·华为·ai编程·harmonyos·atomcode·c/c++三方库
风满城338 小时前
鸿蒙原生应用实战(三):设置与统计页面开发 — 数据驱动的功能模块
harmonyos
KKKlucifer8 小时前
数据安全管控产品选型排名与深度解析
网络·安全
xcLeigh8 小时前
鸿蒙平台 KeePass 密码管理器适配实战:从 Windows 到 鸿蒙PC 的 Electron 迁移指南
windows·electron·web·harmonyos·加密算法·keepass
金启攻8 小时前
鸿蒙原生应用开发实战(一):从零搭建“钓点日记“——项目初始化与环境配置全指南
harmonyos
风华圆舞8 小时前
鸿蒙语音识别为什么要区分 startListening 和 stopListening
华为·语音识别·harmonyos
YM52e9 小时前
鸿蒙PC ArkTS 声明合并问题深度解析与最佳实践
学习·华为·harmonyos·鸿蒙·鸿蒙系统
互联网散修9 小时前
鸿蒙实战:网络状态监听与诊断工具
网络·华为·harmonyos·网络状态监听
其实防守也摸鱼9 小时前
软件安全与漏洞--软件安全编码与防御技术理论题库
开发语言·网络·安全·网络安全·软件安全·软件安全与漏洞