你是否每次手动更改发布证书打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(OhosPluginId.OHOS_APP_PLUGIN) as OhosAppContext;
const profileOpt = appCtx.getBuildProfileOpt()
if (hvigor.getCommandEntryTask() === 'assembleApp') {
const signArray = profileOpt['app']['signingConfigs']
for (const element of signArray) {
element['material']['profile'] = 'key/key_release.p7b'
element['material']['certpath'] = 'key/key_release.cer'
element['material']['storePassword'] = 'password_release'
element['material']['keyPassword'] = 'password_release'
}
}
appCtx.setBuildProfileOpt(profileOpt)
})
打包时如何动态设置APP版本和日期
我们可以在根目录下的hvigorfile.ts中动态获取项目的版本号以及通过Date获取打包时的日期时间,并追加到APP的名称上,示例如下
import { appTasks, OhosAppContext, OhosPluginId } from '@ohos/hvigor-ohos-plugin';
import { hvigor } from '@ohos/hvigor'
hvigor.getRootNode().afterNodeEvaluate(node => {
const appCtx = node.getContext(OhosPluginId.OHOS_APP_PLUGIN) as OhosAppContext;
const profileOpt = appCtx.getBuildProfileOpt()
const jsonOpt = appCtx.getAppJsonOpt()
const products = profileOpt['app']['products']
for (const element of products) {
element['output']['artifactName'] += `-${jsonOpt['app']['versionName']}-${getDate()}`
}
appCtx.setBuildProfileOpt(profileOpt)
})
function getDate(): string {
const date = new Date()
const dateStr = `${date.getFullYear()}${parseNum(date.getMonth() + 1)}${parseNum(date.getDate())}`
const timeStr = `${parseNum(date.getHours())}${parseNum(date.getMinutes())}${parseNum(date.getSeconds())}`
return `${dateStr}${timeStr}`
}
function parseNum(num: number): string {
return num < 10 ? `0${num}` : `${num}`
}
假如我们在build-profile.json5中配置artifactName的值为app,则打包的名称为app-1.0.0-20241027204510.app
如何根据不同的环境依赖不同的库
比如我们要在开发环境依赖flutter的debug包,在生产环境依赖flutter的release包该怎么处理呢?我们可以在oh-package.json5中先配置debug包,在模块下的hvigorfile.ts中检测到当前是生产环境,则动态的将依赖包替换为release版本。oh-package.json5的配置如下
{
"dependencies": {
"flutter": "file:libs/flutter_debug.har"
}
}
假如生产环境的product配置为prod,则hvigorfile.ts中的示例如下
import { hapTasks, OhosHapContext, OhosPluginId } from '@ohos/hvigor-ohos-plugin'
import { getNode } from '@ohos/hvigor'
const entryNode = getNode(__filename)
entryNode.afterNodeEvaluate(node => {
const hapCtx = node.getContext(OhosPluginId.OHOS_HAP_PLUGIN) as OhosHapContext
hapCtx.targets((target)=>{
if (target.getCurrentProduct().getProductName() === 'prod') {
const depOpt = hapCtx.getDependenciesOpt()
depOpt["flutter"]="file:libs/flutter_release.har"
hapCtx.setDependenciesOpt(depOpt)
}
})
})
在hvigorfile.ts中可以做很多事情,可以动态更改app.json5、module.json5、build-profile.json5和oh-package.json5中的很多内容,大家可以多尝试尝试,有了这些能力,就不用担心打包时忘记更改或改错了。
相关推荐
在深入学习华为鸿蒙系统HarmonyOS之前,首要任务是搭建一个完整的开发环境。本文将详细讲解如何进行鸿蒙开发环境的搭建,包括安装Node.js环境和设置HUAWEI DevEco Studio IDE。 一、安装Node.js环境 Node.js是...
在本项目中,我们主要关注的是基于HarmonyOS 4构建的一款刷题应用程序的源代码。...同时,它也是一个很好的学习案例,可以帮助开发者快速上手HarmonyOS应用的开发,提高编程技能,适应鸿蒙生态的开发环境。
在完成开发环境的配置和HarmonyOS SDK的下载后,可以开始编写Hello World程序。Hello World程序是HarmonyOS开发的入门程序,旨在帮助开发者快速上手HarmonyOS开发。 工程管理 HarmonyOS工程管理是指对HarmonyOS...
华为鸿蒙HarmonyOS开发者资料大全是一份专为想要学习和深入理解鸿蒙操作系统开发的初学者准备的综合资源包。这份7z压缩文件包含了丰富的教程、文档、示例代码和工具,旨在帮助开发者快速掌握鸿蒙系统的开发技能。...
在鸿蒙系统(HarmonyOS)的应用开发过程中,动态环境配置切换是一项重要的功能。它允许开发者根据不同的运行环境(如开发、测试、生产等)来调整应用的行为。本文将详细介绍如何利用鸿蒙系统的首选项机制来实现环境...
因此,"鸿蒙版axios请求封装包"是为了满足开发者在HarmonyOS环境下使用类似`axios`的API进行网络请求的需求而创建的。 这个封装包的目标是将`axios`的功能与HarmonyOS的特性相结合,提供一套简洁、高效且易于使用的...
鸿蒙设备开发环境配置部分安装包
华为鸿蒙HarmonyOS开发者资料汇总是一份针对鸿蒙操作系统进行软件开发的全面参考资料集合。这份资料包涵盖了从开发环境的搭建到各种功能模块的实现,旨在帮助开发者深入理解和熟练运用HarmonyOS进行应用程序的开发。...
要开始HarmonyOS开发,首先需要安装DevEco Studio,这是华为提供的集成开发环境。下载并安装后,可以创建项目,选择对应的设备类型(例如手机、平板或智能电视),然后配置编译环境,如SDK、NDK等。此外,还需要了解...
02_HCIA-HarmonyOS Application Developer V1.0 实验环境搭建指南中,详细介绍了如何配置开发环境,包括安装 HarmonyOS SDK、设置开发工具(如DevEco Studio)、连接模拟器或真实设备,以及调试工具的使用方法。...
- DevEco Studio是HarmonyOS应用开发的核心工具,它是一个一站式集成开发环境,支持项目的创建、编辑、调试和发布等功能。 - `main_pages.json` 文件存储了应用页面的路径配置信息,帮助系统管理和组织页面结构。 ...
【HarmonyOS应用开发者基础题库】主要涵盖了鸿蒙系统应用开发的基础知识,涉及DevEco Studio集成开发环境、 ArkTS编程语言、应用程序框架以及页面布局设计等方面。 1. **DevEco Studio**:它是华为提供的开发...
鸿蒙hap格式安装及环境配置
在鸿蒙HarmonyOS开发中,自定义标题栏是一个常见的需求,这有助于为应用程序提供独特的用户界面和交互体验。@BuilderParam装饰器和@Builder函数是HarmonyOS SDK中的两个关键工具,它们允许开发者轻松创建和配置...
1.DevEco Studio是开发HarmonyOS应用的一站式集成开发环境。 (正确) 2.main_pages.json存放页面page路径配置信息。(正确) 3.循环渲染ForEach可以从数据源中迭代获取数据,并为每个数组项创建相应的组件。(正确...
HarmonyOS是华为开发的操作系统,旨在实现多设备协同,具有分布式架构特点。镜像烧录是将操作系统或软件的映像文件(bin文件)写入到硬件设备(如板卡)中,使其能够执行。Linux服务器上进行WLAN模组版本编译是...
【 HarmonyOS 应用开发者高级认证】涉及到的知识点主要涵盖 HarmonyOS 应用的开发、设计、部署和测试等方面。以下是这些知识点的详细说明: **一、端云一体化开发** 1. **端云一体化开发**:允许开发者通过统一的...
《华为DevEco Studio使用指南》是为鸿蒙开发者提供的一份详尽的开发环境配置与使用手册。鸿蒙学堂,作为华为官方的学习平台,致力于为开发者提供最全面、最新的鸿蒙系统开发教程和资源。这份文档将带你深入了解如何...
鸿蒙HarmonyOS的一大亮点是其分布式能力,C++开发者需要学习如何在分布式环境下编写代码,例如数据同步、服务发现和远程调用等。这涉及到对HarmonyOS的Distributed Data Management (DDM) 和Distributed Capability...
在本文中,我们将详细讨论如何在Ubuntu 18.04及以上版本上搭建华为HarmonyOS的实验环境。 一、系统要求 1. **Ubuntu 18.04或更高版本**:这是开发鸿蒙设备的基础操作系统,因为鸿蒙OS的开发工具对Ubuntu有良好的...