你是否每次手动更改发布证书打app包上加应用市场呢?你是否每次打完包都手动在名称后添加版本号和时间呢?不同环境的依赖包经常打包时忘记改呢?其实这些鸿蒙都支持动态配置。
认识hvigor编译构建
hvigor将工程解析为一个树形结构,项目为树的根节点,项目中的每个模块为树的叶子节点,树最多为两层,模块中不能包含其他模块,在hvigor的定义中统称项目或模块为一个node(节点)。在构建最开始的初始化阶段,会通过hvigorconfig.ts文件以及工程级build-profile.json5文件中的配置来构造出一个树形结构存储项目的工程结构,工程级build-profile.json5文件和hvigorconfig.ts文件均可以配置多模块。
hvigor是基于任务对您的项目进行自动化构建的,任务(Task)是hvigor构建过程中的基本工作单元,它定义了构建项目时需要执行的具体工作。任务可以完成多种操作,比如源码编译任务,打包任务或签名任务等。每一种任务的执行逻辑由插件(plugin)提供,插件可以是由hvigor-ohos-plugin提供的默认任务逻辑,也可由您个性化定制。
如何动态配置发布证书
发布证书是在应用打包APP上架应用市场时使用,所以有人将debug环境配置为调试证书,release环境配置为发布证书是不对的,用发布证书打包的应用是不能直接运行到手机上。
我们可以对比一下调试证书和发布证书,不一样的是profile、certpath、keyPassword和storePassword,我们只需要在hvigor中判断当前任务是在打包APP,就可以将这些值动态替换为发布证书的值。比如我们正常在build-profile.json5中配置调试证书如下
{
"app": {
"signingConfigs": [
{
"name": "default",
"type": "HarmonyOS",
"material": {
"keyAlias": "harmony",
"storeFile": "key/key.p12",
"signAlg": "SHA256withECDSA",
"profile": "key/key_debug.p7b",
"certpath": "key/key_debug.cer",
"keyPassword": "password_debug",
"storePassword": "password_debug"
}
}
]
}
}
在根目录下的hvigorfile.ts可以这么处理
import {
appTasks, OhosAppContext, OhosPluginId } from '@ohos/hvigor-ohos-plugin';
import {
hvigor } from '@ohos/hvigor'
hvigor.getRootNode().afterNodeEvaluate(node => {
const appCtx = node.getContext


2621

被折叠的 条评论
为什么被折叠?



