快速修复概述
快速修复是HarmonyOS系统提供给开发者的一种技术手段,支持开发者以远快于应用升级的方式对应用程序包进行缺陷修复。和全量应用升级软件版本相比,快速修复的主要优势在小、快和用户体验好。在较短的时间内不中断正在运行的应用的情况下(即不需要重启应用),修复应用的缺陷。
快速修复的使用规则
-
仅支持修复应用的TS和C++代码,对应的文件为.abc文件(TS编译后的文件)和.so文件(C++编译后的文件),不支持对资源的修复。
-
不支持新增.abc文件和.so文件。
-
快速修复包部署时要确保对应应用包已安装,如果未安装,则部署失败。
-
快速修复包中配置的包名和应用版本号必须和已安装的包名和版本号应用相同,如果不同则部署失败。
-
如果已经部署过快速修复包,新部署的快速修复包的版本号必须大于之前快速修复包的版本号,否则部署失败。
-
快速修复包的签名信息和待修复的应用的签名信息必须一致,否则会部署失败。
-
新的应用版本发布安装时,会清理掉快速修复包。
快速修复包结构
上图是HarmonyOS应用程序发布的快速修复的包格式
-
从图中可以看出包含两种包格式:
-
appqf(Application Quick Fix)
appqf与应用的app pack包是一一对应关系,具体可参考
应用程序包结构
的介绍。
-
appqf包是HarmonyOS应用用于发布到应用市场的单元,不能够直接安装到设备上。
-
它是由一个或多个hqf(Harmony Ability Package Quick Fix)组成,这些hqf包在应用市场会从appqf包中拆分出来,再被分发到具体的设备上。
-
appqf包上架到应用市场前要有开发者的签名信息。
-
hqf(Harmony Ability Package Quick Fix)
hqf包是修复HAP中问题的快速修复包,用于安装到设备上的快速修复单元。一个hqf可以包含.abc的快速修复文件,.so的快速修复文件和描述该包的配置文件。
-
.abc文件:应用中修改后的ts代码,编译后生成的字节码文件。
-
libs目录:存放.so库文件的差分文件,以.so.diff为后缀。区分的不同的系统cpu架构,例如arm平台、x86平台。
-
patch.json:
该文件用于描述hqf包版本信息的配置文件,由开发者填写,具体内容如下:
{ "app" : { "bundleName" : "com.ohos.quickfix", "versionCode" : 1000000, "versionName" : "1.0.0", "patchVersionCode" : 1000000, "patchVersionName" : "1.0.0" }, "module" : { "name" : "entry", "type" : "patch", "deviceTypes" : [ "default", "tablet" ], "originalModuleHash" : "11223344556677889900" }}
具体字段说明:
字段
|
类型
|
说明
|
备注
|
bundleName
|
string
|
对应应用的包名。
|
不可缺省
|
versionCode
|
int
|
对应应用版本号。
|
不可缺省
|
versionName
|
string
|
对应应用的版本名称。
|
patch类型不可缺省
|
patchVersionCode
|
int
|
补丁包的版本号。
|
不可缺省
|
patchVersionName
|
string
|
补丁包的版本名称。
|
patch类型不可缺省
|
name
|
string
|
对应应用的moduleName,用来修复该module的。
|
不可缺省
|
type
|
string
|
对应补丁包的类型,当前可选择为patch。
|
不可缺省
|
deviceTypes
|
array
|
补丁包支持的设备类型。
|
不可缺省
|
originalModuleHash
|
string
|
原始module Name对应包的哈希值,可采用SHA256生成器自行生成。
|
不可缺省
|
快速修复TS编译后的文件
上图是通过TS代码编译工具生成快速修复.abc文件的流程:
-
原始应用编译时,生成.abc文件和.map文件。.abc是TS代码编译后的字节码文件,应用运行时使用该文件。.map文件是通过TS代码编译工具编译TS代码时生成的中间文件,记录有代码中的函数、类等信息。
-
修复问题后的应用编译时,根据上述的.map文件,结合当前的TS代码,得到差异部分,根据差异部分生成快速修复的.abc文件。该.abc文件也既是最终要放到hqf包中的快速修复文件。
快速修复C++编译后的文件
上图是通过差分工具生成快速修复.so文件的流程:
-
原始应用C++源码通过编译工具生成.so文件,该.so文件供应用在运行时使用。
-
修复问题后的C++源码通过编译工具生成.so文件,该.so文件和原应用的.so文件通过差分工具生成.so快速修复文件,该.so快速修复文件也既是最终要放到hqf包中的快速修复文件。
快速修复包的发布部署流程
上图涉及到的模块如下:
-
DevEco Studio:用于开发代码的项目工程的集成开发环境。在快速修复的工程中能够给予原应用的代码和修复问题后的代码生成快速修复包,并完成快速修复包的签名。
-
应用市场服务器端:开发者将开发完成的快速修复包上架到该平台,平台会对上架的包进行签名验证、风险扫描和拆包重签名等,然后分发到客户端。
-
应用市场客户端:用于接收应用市场服务器端分发的快速修复包,并触发安装快速修复包。
-
包管理服务:设备上用于管理应用包及快速修复包安装和卸载的系统服务程序。
-
快速修复引擎:设备上用于管理应用切换使用快速修复包的系统服务程序。如果应用正在运行,快速修复引擎接收到有快速修复包部署完成会通知应用切换快速修复包,进而使得应用使能快速修复包。
-
文件系统:应用及快速修复包部署在设备上的位置。
上图是快速修复包的端到端发布部署流程:
-
开发者通过DevEco Studio,基于原应用的源码和修复后的源码编译打包生成快速修复包,并通过DevEco Studio完成快速修复包的签名。
-
将生成的带有签名的快速修复包上架到应用市场,应用市场通过验证签名、风险扫描和拆包重签名后进行分发。
-
设备侧的应用市场客户端检测到应用市场服务器端有新上架的快速修复包会下载最新版本的快速修复包,接着通过系统中的包管理服务来安装部署快速修复包。
-
快速修复包部署完成后,再由快速修复引擎触发应用使用快速修复包,进而保证用户使用到问题修复后的功能。
快速修复包的调试流程
-
DevEco Studio中暂时还没有集成快速修复的能力。当前阶段,HarmonyOS为开发者提供了命令行的调试开发工具可供使用,具体的调试开发流程如下:
-
基于原应用的源码和修复后的源码,通过命令行工具可以编译生成快速修复包,并通过命令行签名工具完成对快速修复的包的签名。通过命令行调试开发,要对.hqf包签名,并通过命令行工具将.hqf包安装到设备上,.appqf包不能直接安装到设备上。
-
通过快速修复的命令行工具,将.hqf包安装部署到设备上。
-
.hqf包安装部署完成后,回调通知快速修复引擎触发应用使用快速修复包,进而保证用户使用到问题修复后的功能。
最后
这里整理了一份《鸿蒙零基础入门学习指南》,希望能对那些想要学习鸿蒙,但是有没有方向的人提供一点帮助。本文档适用于HarmonyOS应用开发的初学者(由于文档内容过多,因此为了避免影响到大家的阅读体验,在此只以截图展示部分内容,详细完整版的看文末有免费的获取方式!)
《鸿蒙零基础入门学习指南》
目录
一、快速入门
适用于HarmonyOS应用开发的初学者。通过构建一个简单的具有页面跳转/返回功能的应用,快速了解工程目录的主要文件,熟悉HarmonyOS应用开发流程。
-
开发准备
-
构建第一个ArkTS应用(Stage模型)
-
构建第一个ArkTS应用(FA模型)
-
构建第一个JS应用(FA模型)
二、开发基础知识
-
应用程序包基础知识
-
应用程序包概述
-
应用程序包结构
-
应用程序包多HAP机制
-
应用程序包安装和卸载流程
-
应用程序包更新流程
-
共享包
-
应用程序包快速修复
-
应用配置文件(Stage模型)
-
应用配置文件概述(Stage模型)
-
app.json5配置文件
-
module.json5配置文件
-
应用配置文件概述(FA模型)
-
应用配置文件概述(FA模型)
-
app对象内部结构
-
deviceConfig内部结构
-
module对象内部结构
三、资源分类与访问
应用开发过程中,经常需要用到颜色、字体、间距、图片等资源,在不同的设备或配置中,这些资源的值可能不同。
-
资源分类与访问
-
创建资源目录和资源文件
-
创建资源目录和资源文件
-
创建资源目录
-
创建资源文件
-
资源访问
-
应用资源
-
系统资源
-
资源匹配
四、学习ArkTs语言
ArkTS是HarmonyOS优选的主力应用开发语言。ArkTS围绕应用开发在
TypeScript
(简称TS)生态基础上做了进一步扩展,继承了TS的所有特性,是TS的超集。因此,在学习ArkTS语言之前,建议开发者具备TS语言开发能力。
-
初识ArkTS语言
-
基本语法
-
状态管理
-
其他状态管理
-
其他状态管理概述
-
@Watch装饰器:状态变量更改通知
-
$$语法:内置组件双向同步
-
渲染控制
-
渲染控制概述
-
if/else:条件渲染
-
ForEach:循环渲染
-
LazyForEach:数据懒加载
扫描下方二维码免费领取,《鸿蒙5.0零基础入门学习指南》