【HarmonyOS开发】HAP包与APP包
我们在DevEco编辑器中完成项目之后经常会在构建窗口中编译项目的时候,看到有两个选项,分别是Hap与APP:那么就让我们来深入探究一下这两个包的区别与联系吧。
我们在DevEco编辑器中完成项目之后经常会在构建窗口中编译项目的时候,看到有两个选项,分别是Hap与APP:
那么就让我们来深入探究一下这两个包的区别与联系吧
Hap与APP包
首先需要理解Hap和APP包都分别是什么
Hap
Hap的全称为“HarmonyOS Ability Package”,它是Ability的部署包(Hap内带有Ability组件),也是应用安装和运行的基本单元。HAP包是由代码、资源、第三方库、配置文件等打包生成的模块包。
Hap包的类型
hap包有两种类型,分别是entry和feature
- entry:应用的主模块,作为应用的入口,提供了应用的基础功能。
- feature:应用的动态特性模块,作为应用能力的扩展,可以根据用户的需求和设备类型进行选择性安装。
entry类型和feature类型的区别
- entry类型的HAP:是应用的主模块,在module.json5配置文件中的type标签配置为“entry”类型。然而feature类型的HAP是应用的动态性模块,在module.json5文件中的type标签配置为“feature”类型。
- 在同一个应用中,同一设备类型只支持一个entry类型的HAP,通常用于实现应用的入口界面、入口图标、主特性功能等。一个应用程序包可以包含一个或多个Feature类型的HAP,也可以不包含;Feature类型的HAP通常用于实现应用的特性功能,可以配置成按需下载安装,也可以配置成随Entry类型的HAP一起下载安装。
Hap包的结构
将一个项目打包成Hap,可以在目录中看到有一个hap文件和info文件
其实本质上这个hap文件就是一个压缩包,可以更改后缀名为zip解压压缩包看下 hap 包里的文件结构,解压出来的文件结构如下所示:
可以看到解压之后,里面目录结构包含了ets、resources两个目录和三个配置文件。
- ets:编译后的源码文件
- modules.abc:源码编译之后的方舟字节码
- sourceMaps.map:abc文件的索引文件
- resources:资源文件,包括图片、字符串、音频和rawfile中的文件等
- module.json:hap包的配置文件
- pack.info:配置文件
- resources.index:资源目录的索引文件
abc 文件表示方舟字节码(ark bytecode,简称 abc),所以项目运行的时候 ark 虚拟机需要加载运行这些 abc 文件。module.json 是项目里的默认配置文件,只是在打包的时候添加了一些额外的默认配置。
Hap包的限制
-
不支持导出接口和ArkUI组件,给其他模块使用。
-
多HAP场景下,App Pack包中同一设备类型的所有HAP中必须有且只有一个Entry类型的HAP,Feature类型的HAP可以有一个或者多个,也可以没有。
-
多HAP场景下,同一应用中的所有HAP的配置文件中的bundleName、versionCode、versionName、minCompatibleVersionCode、debug、minAPIVersion、targetAPIVersion、apiReleaseType相同,同一设备类型的所有HAP对应的moduleName标签必须唯一。HAP打包生成App Pack包时,会对上述参数配置进行校验。
-
多HAP场景下,同一应用的所有HAP、HSP的签名证书要保持一致。上架应用市场是以App Pack形式上架,应用市场分发时会将所有HAP从App Pack中拆分出来,同时对其中的所有HAP进行重签名,这样保证了所有HAP签名证书的一致性。在调试阶段,开发者通过命令行或DevEco Studio将HAP安装到设备上时,要保证所有HAP签名证书一致,否则会出现安装失败的问题。
APP
APP包是用于上架发布的。 根据不同的设备类型,一个APP包可以由多个HAP包,以及描述APP 包属性的pack.info文件组成。
一个 APP 中可以包含多个 HAP,但必须含有 Entry.HAP;一个 APP 可包含多个 Feature.HAP,也可以不包含 Feature.HAP。
Hap与APP的区别
1、编译构建角度
- 编译构建是将HarmonyOS应用的源代码、资源、第三方库等打包生成HAP或者APP的过程。其中,HAP可以直接运行在真机设备或者模拟器中;APP则是用于应用上架到华为应用市场。
- 一个HarmonyOS工程下可以存在多个Module,在编译构建时,可以选择对单个Module进行编译构建;也可以对整个工程进行编译构建,同时生成多个HAP。
2、签名角度
APP
- HarmonyOS应用发布形态为APP Pack(Application Package,简称APP),它是由一个或多个HAP(HarmonyOS Ability Package)包以及描述APP Pack属性的pack.info文件组成。
Hap
- 一个HAP在工程目录中对应一个Module,它是由代码、资源、第三方库及应用配置文件组成,可以分为Entry和Feature两种类型。Entry:应用的主模块。一个APP中,对于同一设备类型必须有且只有一个entry类型的HAP,可独立安装运行。Feature:应用的动态特性模块。一个APP可以包含一个或多个feature类型的HAP,也可以不含。
- HAP是Ability的部署包,HarmonyOS应用代码围绕Ability组件展开,它是由一个或多个Ability组成。
- 一个App可以有很多HAP。HAP可以直接在模拟器或者真机设备上运行,用于HarmonyOS应用开发阶段的调试和查看运行效果。
- 原子化服务由1个或多个HAP包组成,1个HAP包对应1个FA或1个PA。每个FA或PA均可独立运行,完成1个特定功能;1个或多个功能(对应FA或PA)完成1个特定的便捷服务。
鸿蒙应用在设备中的启动流程
- 桌面点击应用App图标
- 操作系统检测到应用启动请求,并根据应用的包名和入口信息找到对应的 HAP 包路径
- 操作系统加载 HAP 包的信息,并解析其中的配置文件,如 pack.info、module.json等
- 操作系统根据配置文件中的入口信息,找到应用的入口类和入口方法
- 操作系统创建应用的运行环境,并执行应用的入口类和入口方法
- 应用的入口方法执行初始化操作,如创建应用窗口、注册事件监听器等,加载资源文件
- 应用初始化完成后,执行渲染页面,执行生命周期,进行网络请求等
- 用户关闭应用,应用关闭
更多推荐
所有评论(0)