hpack - HarmonyOS 内测打包分发工具
简介
hpack 是一个专为 HarmonyOS 打造的内测分发工具,借助它,你只需一行命令,就能轻松完成鸿蒙应用的构建、打包、签名,并将其上传至服务器进行内测分发。
这大大简化了开发流程,提高了开发效率,让你能更专注于应用的开发和优化。
功能特性
- 打包签名:自动打出所有的 hap 和 hsp 包,并对它们进行签名。
- 签名 Manifest.json5:读取应用打包数据,自动生成已签名的
Manifest.json5
文件。 - 分发 index 页:自动生成分发页,提供多种 HTML 模板,如
default
,tech
,cartoon
,tradition
,同时支持自定义模板,满足不同的展示需求。 - 二维码生成:自动生成应用的二维码,方便内测人员快速下载和安装。
- OSS 上传:如果完成配置,可将打包好的所有文件上传到阿里云 OSS 。
安装使用
在阅读以下内容之前,我们建议你先详细阅读鸿蒙官方文档 HarmonyOS 应用内部测试。
准备工作,你需要生成这三个文件:
1、发布证书: .cer 格式
2、内部测试 Profile: .p7b 格式
3、私钥文件: .p12 格式
官方给出的内部测试流程大致如下:
预置环境:
DevEco-Studio :鸿蒙开发 IDE, 同时集成了各种命令工具
JDK 17+: 签名工具需要。
python3.7+ : hpack 由 python 编写,执行环境
# 在你使用的终端中,检查以下工具是否成功安装:
java --version
python3 --version # 或 python
pip3 --version # 或 pip
hvigorw -v # DevEco-Studio 自带,其他终端使用需设置环境变量,请看下面 Tips
安装 hpack
pip3 install harmony-hpack # 最新版本 pip3 install harmony-hpack==1.0.0
查看帮助信息
hpack -h # hpack help
查看版本信息
hpack -v # hpack --version
初始化
在项目根目录下执行以下命令,初始化 hpack
目录并创建配置文件:
hpack init
初始化完成后,会在项目根目录下生成 hpack
目录,包含以下文件和文件夹:
.
├── config.py # 配置文件,服务器、应用信息和打包签名等相关信息。
├── Packfile.py # 打包完成后的回调文件,可用于自定义上传和处理逻辑。
└── sign # 用于存放签名证书文件。
完成配置
打开 hpack/config.py
文件,根据实际情况修改配置信息:
class Config:
# 安装包存放的服务器的域名
DeployDomain = 'static.hpack.com'
# 安装包存放的服务器地址,必须是 https
BaseURL = f"https://{DeployDomain}/hpack"
# 应用信息
AppIcon = f"{BaseURL}/AppIcon.png"
AppName = 'hpack'
Badge = '鸿蒙版'
# index模板选择, 可选值为 [default, simple, tech, cartoon, tradition, custom]
# 如果是 custom,则表示自定义模板,需要自己在 hpack 目录写一个 index.html,
# 打包完成后进行内容填充,再写入 hpack/build 目录
IndexTemplate = "default"
# 打包签名配置
Alias = 'your key alias'
KeyPwd = 'your key password'
KeystorePwd = 'your store password'
# 替换 hapck/sign 目录下的证书文件
SignDir = 'sign'
Cert = os.path.join(SignDir, 'release.cer')
Profile = os.path.join(SignDir, 'test_release.p7b')
Keystore = os.path.join(SignDir, 'harmony.p12')
替换 hapck/sign
目录下的证书文件
.
├── harmony.p12 # 私钥文件
├── release.cer # 发布证书
└── test_release.p7b # 内部测试Profile
打包与上传
如果使用阿里云OSS 作为存储服务,需要先安装 oss2:
pip3 install oss2
打开 Packfile.py
完成配置:
class OSSConfig:
# 如果您需要使用OSS, 需要先安装 pip3 install oss2
# 如果您不使用阿里云OSS,则不用修改
Access_key_id = 'your Access_key_id'
Access_key_secret = 'your Access_key_secret'
Endpoint = 'your Endpoint'
Bucket_name = 'your Bucket_name'
Bucket_dir = 'hpack'
如果是使用的是其他服务器,则需要自己编写上传代码:
def didPack(packInfo):
"""_summary_: 打包后回调,通常在这里上传打包结果到服务器
"""
# 打包结果在hapck/build,编写你的上传逻辑
执行以下命令进行打包、签名和上传操作,可选择性地添加更新说明:
hpack pack "修复了一些已知问题,优化了性能" # 缩写 hpack p [desc]
打包完成后,所有打包的文件都在 hpack/build
目录下。
运行示例图
开始打包
打包完成
安装
模板图预览
hpack 提供多种内置分发页模板,满足不同风格的需求
# config.py
# index模板选择, 可选值为 [default, simple, tech, cartoon, tradition, custom]
IndexTemplate = "default"
![]() | ![]() | ![]() |
---|---|---|
default 默认风格 | simple 简单 | tech 科技 |
![]() | ![]() |
---|---|
cartoon 卡通 | tradition 传统 |
如何自定义分发页 index.html
1、修改 config.py
文件的模板配置项为 custom
IndexTemplate = 'custom' # 表面自定义模板
2、如果你想使用 hpack 提供的 HTML 模板来做进一步修改,可以执行以下命令:
hpack template [tname] # 缩写 hpack t tech
tname
可选值为 default
, simple
, tech
, cartoon
, tradition
,如果不指定,默认使用 default
模板。
这个命令会在 hpack/
目录下生成对应的 index.html
模板文件。
如果不使用模板,则需要手动新建 index.html
文件到 hpack/
目录。
3、在 Packfile.py
打开关于自定义模板的注释:
def customTemplateHtml(templateInfo):
packInfo = templateInfo["packInfo"]
html = templateInfo["html"]
date = datetime.now().strftime("%Y-%m-%d %H:%M")
# 请修改自定义的 hapck/index.html
# 完成对应 $变量的填充
template = Template(html)
html_template = template.safe_substitute(
app_icon=Config.AppIcon,
title=Config.AppName,
badge=Config.Badge,
date=date,
version_name=packInfo["version_name"],
version_code=packInfo["version_code"],
size=packInfo["size"],
desc=packInfo["desc"],
manifest_url=packInfo["manifest_url"],
qrcode=packInfo["qrcode"]
)
print(html_template) # 打印到标准输出,用于传参,不可删除
if __name__ == "__main__":
elif args.t:
# 从标准输入读取 JSON 数据
templateInfo = json.loads(sys.stdin.read())
customTemplateHtml(templateInfo)
4、执行打包命令 hpack p '自定义index.html'
Tips:
1、在非 DevEco-Studio 的终端执行命令时,需要配置 hvigorw
的环境变量
# Mac
export DEVECO_SDK_HOME=/Applications/DevEco-Studio.app/Contents/sdk
# win
https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/ide-hvigor-commandline
# 查看是否成功
hvigorw -v
2、如果已安装的 App 和准备要安装的 App 打包证书不一致,需先卸载已安装的 App 。
3、安装时鸿蒙会进行联网校验,手机如果开了代理需要注意下。
4、安装出错时会有提示,根据错误码找原因。错误码说明。
5、在 .gitigore
文件中添加忽略
.gitigore 文件
# 忽略 __pycache__ 目录
__pycache__/
贡献
如果你有任何建议或发现了 bug,欢迎提交 issues 或 pull requests,让 hpack 变得更好!