鸿蒙Stage模型应用程序包结构

1、开发态包结构

在DevEco Studio上创建一个项目工程,理解开发态的应用程序结构。

AppScope目录由开发工具自动生成。

AppScope > app.json5:声明应用的全局配置信息,比如应用Bundle名称、应用名称、应用图标、应用版本号等。

AppScope > resources :用于存放应用需要用到的资源文件。

Module_name > src > main > module.json5:声明Module基本信息、支持的设备类型、所含的组件信息、运行所需申请的权限等。

Module_name > src > main > ets:用于存放Module的ArkTS源码文件。

Module_name > src > main > resources :用于存放该Module需要用到的资源文件。

build-profile.json5:工程级或Module级的构建配置文件,包括应用签名、产品配置等。

hvigorfile.ts:应用级或Module级的编译构建任务脚本,开发者可以自定义编译构建工具版本、控制构建行为的配置参数。

obfuscation-rules.txt:混淆规则文件。

oh-package.json5:用于存放依赖库的三方库和共享包信息。

2、编译包结构

不同类型的Module编译后会生成对应的HAP、HAR、HSP等文件,开发态视图与编译态视图的对照关系如下:

从开发态到编译态,Module中的文件会发生如下变更:

  • ets目录:ArkTS源码编译生成.abc文件。
  • resources目录:AppScope目录下的资源文件会合入到Module下面资源目录中。
  • module配置文件:AppScope目录下的app.json5文件字段会合入到Module下面的module.json5文件。

3、发布态包结构

每个应用中至少包含一个.hap文件,可能包含若干个.hsp文件、也可能不含,一个应用中的所有.hap与.hsp文件合在一起称为Bundle,其对应的bundleName是应用的唯一标识。

当应用发布上架到应用市场时,需要将Bundle打包为一个.app后缀的文件用于上架,这个.app文件称为App Pack (Application Package),与此同时,DevEco Studio工具自动会生成一个pack.info 文件。pack.info文件描述了App Pack中每个HAP和HSP的属性,包含APP中的bundleName和versionCode信息、以及Module中的name、type和abilities等信息。

4、HAP、HAR、HSP使用总结

Module类型 包类型 说明
Ability HAP 应用个功能模块,可独立运行,可包含一个或多个feature类型的HAP
Static Library HAR 静态共享包,编译态服用(应用内、二方库、三方库)
Shared Library HSP 动态共享包,运行时复用。多包同时引用HSP时,代码和资源不会重复拷贝。
相关推荐
anyup8 小时前
🔥2026最推荐的跨平台方案:H5/小程序/App/鸿蒙,一套代码搞定
前端·uni-app·harmonyos
Ranger092913 小时前
鸿蒙开发新范式:Gpui
rust·harmonyos
Huang兄13 小时前
鸿蒙-深色模式适配
harmonyos·arkts·arkui
SummerKaze2 天前
为鸿蒙开发者写一个 nvm:hmvm 的设计与实现
harmonyos
在人间耕耘4 天前
HarmonyOS Vision Kit 视觉AI实战:把官方 Demo 改造成一套能长期复用的组件库
人工智能·深度学习·harmonyos
王码码20354 天前
Flutter for OpenHarmony:socket_io_client 实时通信的事实标准(Node.js 后端的最佳拍档) 深度解析与鸿蒙适配指南
android·flutter·ui·华为·node.js·harmonyos
HarmonyOS_SDK4 天前
【FAQ】HarmonyOS SDK 闭源开放能力 — Ads Kit
harmonyos
Swift社区4 天前
如何利用 ArkUI 框架优化鸿蒙应用的渲染性能
华为·harmonyos
特立独行的猫a4 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS影视票房榜组件完整实现过程
华为·uni-app·harmonyos·轮播图·uniapp-x
盐焗西兰花4 天前
鸿蒙学习实战之路-STG系列(5/11)-守护策略管理-添加与修改策略
服务器·学习·harmonyos