1# Hap包签名工具 2 3* 简介 4* 目录 5* 约束 6* 编译构建 7* 说明 8 * 签名相关文件用法说明 9 * 使用说明 10 * 接口说明 11* 相关仓 12 13#### 简介 14 15为了保证OpenHarmony应用的完整性和来源可靠,在应用构建时需要对应用进行签名。经过签名的应用才能在真机设备上安装、运行、和调试。本仓提供了签名工具的源码,包含密钥对生成、CSR文件生成、证书生成、Profile文件签名、Hap包签名等功能。 16 17 18#### 目录 19 20 developtools_hapsigner 21 22 ├── autosign # 一键签名脚本 23 ├── dist # SDK预置文件 24 ├── hapsigntool # 主代码 25 ├──hap_sign_tool # 主程序入口,完成输入参数的基础校验 26 ├──hap_sign_tool_lib # 签名工具库,解析命令字和参数列表,实现各模块逻辑功能 27 ├── tools # 自动化测试脚本 28 29 30 31#### 约束 32Hap包签名工具基于Java语言开发,需要在Java8以上Java环境运行 33(附:一键签名等脚本文件基于Python语言开发,使用需配置环境python3.x) 34#### 编译构建 35 36 1. 该工具基于Gradle 7.1编译构建,请确认环境已安装配置Gradle环境,并且版本正确 37 38 gradle -v 39 40 2. 下载代码,命令行打开文件目录至developtools_hapsigner/hapsigntool,执行命令进行编译打包 41 42 gradle build 或者 gradle jar 43 44 3. 编译后得到二进制文件,目录为: ./hap_sign_tool/build/libs/hap-sign-tool.jar 45 46**** 47#### 说明 48##### 签名相关文件用法说明 49 50开发者通过IDE进行应用签名时,可在SDK中会获得如下签名相关文件: 51 52``` 53签名密钥库文件:OpenHarmony.p12 54Profile签名证书:OpenHarmonyProfileRelease.pem、OpenHarmonyProfileDebug.pem 55Profile模板文件:UnsgnedReleasedProfileTemplate.json、UnsgnedDebugProfileTemplate.json 56签名工具:hap-sign-tool.jar 57``` 58上述文件的使用场景如下图所示。 59 60**Profile签名场景:** 61 62 63 64**应用签名场景:** 65 66 67##### 使用说明 68 69以下说明中使用jar包为编译构建中生成的二进制文件 70 711.命令行签名 72 命令行签名分为profile文件签名和hap包签名。 73 74 (1)签名profile文件的命令实例如下: 75 76 77```shell 78java -jar hap-sign-tool.jar sign-profile -keyAlias "oh-profile1-key-v1" -signAlg "SHA256withECDSA" -mode "localSign" -profileCertFile "result\profile1.pem" -inFile "app1-profile-release.json" -keystoreFile "result\ohtest.jks" -outFile "result\app1-profile.p7b" -keyPwd "123456" -keystorePwd "123456" 79``` 80该命令的参数说明如下: 81 82 sign-profile : ProvisionProfile文件签名 83 ├── -mode #签名模式,必填项,包括localSign,remoteSign 84 ├── -keyAlias #密钥别名,必填项 85 ├── -keyPwd #密钥口令,可选项 86 ├── -profileCertFile #Profile签名证书(证书链,顺序为最终实体证书-中间CA证书-根证书),必填项 87 ├── -inFile #输入的原始Provision Profile文件,必填项 88 ├── -signAlg #签名算法,必填项,包括SHA256withECDSA / SHA384withECDSA 89 ├── -keystoreFile #密钥库文件,localSign模式时为必填项,JKS或P12格式 90 ├── -keystorePwd #密钥库口令,可选项 91 ├── -outFile #输出签名后的Provision Profile文件,p7b格式,必填项 92 93 94 95(2)签名Hap包的命令实例如下: 96 97 98```shell 99java -jar hap-sign-tool.jar sign-app -keyAlias "oh-app1-key-v1" -signAlg "SHA256withECDSA" -mode "localSign" -appCertFile "result\app1.pem" -profileFile "result\app1-profile.p7b" -inFile "app1-unsigned.zip" -keystoreFile "result\ohtest.jks" -outFile "result\app1-unsigned.hap" -keyPwd "123456" -keystorePwd "123456" 100``` 101该命令的参数说明如下: 102 103 sign-app : hap应用包签名 104 ├── -mode #签名模式,必填项,包括localSign,remoteSign 105 ├── -keyAlias #密钥别名,必填项 106 ├── -keyPwd #密钥口令,可选项 107 ├── -appCertFile #应用签名证书文件(证书链,顺序为最终实体证书-中间CA证书-根证书),必填项 108 ├── -profileFile #签名后的Provision Profile文件名,p7b格式,必填项 109 ├── -profileSigned #指示profile文件是否带有签名,1表示有签名,0表示没有签名,默认为1。可选项 110 ├── -inForm #输入的原始文件的格式,zip格式或bin格式,默认zip格式;可选项 111 ├── -inFile #输入的原始APP包文件,zip格式或bin格式,必填项 112 ├── -signAlg #签名算法,必填项,包括SHA256withECDSA / SHA384withECDSA 113 ├── -keystoreFile #密钥库文件,localSign模式时为必填项,JKS或P12格式 114 ├── -keystorePwd #密钥库口令,可选项 115 ├── -outFile #输出签名后的包文件,必填项 116 117 1182.一键签名 119 120 121为降低学习成本,提高开发效率,本项目还将基于应用签名工具提供一键签名脚本,免于输入繁杂的参数命令,脚本内容包括生成密钥对、最终实体证书、签名profile包、签名hap包的命令。 122脚本以及配置文件位于目录autosign下: 123 124 - create_root.sh/create_root.bat 125 - create_appcert_sign_profile.sh/create_appcert_sign_profile.bat 126 - sign_hap.sh/sign_hap.bat 127 - createAppCertAndProfile.config 128 - createRootAndSubCert.config 129 - signHap.config 130 131使用指导: 1321. 准备依赖环境python3.5以上 1332. 准备签名工具jar包:hap-sign-tool.jar(参照上文编译生成的产物) 1343. 准备待签名的应用hap包和Provision profile模板文件 1354. 使用文本编辑器编辑createAppCertAndProfile.config,signHap.config修改配置文件中的配置信息:common.keyPwd 和 common.issuerKeyPwd 参数值改成自己定义的口令信息 1365. Linux运行create_appcert_sign_profile.sh、Windows运行create_appcert_sign_profile.bat生成签名所需文件 1376. Linux运行sign_hap.sh、Windows运行sign_hap.bat对hap包进行签名 138 139 > 说明:如需自定义生成密钥库文件,根CA,中间CA证书,profile签名证书,可执行以下步骤 140 1.使用文本编辑器编辑createRootAndSubCert.config修改配置文件中的配置信息:common.keyPwd 和 common.issuerKeyPwd 参数值改成自己定义的口令信息 141 2.Linux运行 create_root.sh、Windows运行create_root.bat生成所需密钥库文件,根CA,中间CA证书,profile签名证书 142 143 144**** 145##### 接口说明 1461.生成密钥对 147 148 generate-keypair : 生成密钥对 149 ├── -keyAlias # 密钥别名,必填项 150 ├── -keyPwd # 密钥口令,可选项 151 ├── -keyAlg # 密钥算法,必填项,包括RSA/ECC 152 ├── -keySize # 密钥长度,必填项,RSA算法的长度为2048/3072/4096,ECC算法的长度NIST-P-256/NIST-P-384 153 ├── -keystoreFile # 密钥库文件,必填项,JKS或P12格式 154 ├── -keystorePwd # 密钥库口令,可选项 155 1562.生成证书签名请求 157 158 generate-csr : 生成证书签名请求 159 ├── -keyAlias # 密钥别名,必填项 160 ├── -keyPwd # 密钥口令,可选项 161 ├── -subject # 证书主题,必填项 162 ├── -signAlg # 签名算法,必填项,包括SHA256withRSA / SHA384withRSA / SHA256withECDSA / SHA384withECDSA 163 ├── -keystoreFile # 密钥库文件,必填项,JKS或P12格式 164 ├── -keystorePwd # 密钥库口令,可选项 165 ├── -outFile # 输出文件,可选项,如果不填,则直接输出到控制台 166 1673.生成根CA/中间CA证书 168 169 generate-ca : 生成根CA/中间CA证书,如果密钥不存在,一起生成密钥 170 ├── -keyAlias # 密钥别名,必填项 171 ├── -keyPwd # 密钥口令,可选项 172 ├── -keyAlg # 密钥算法,必填项,包括RSA/ECC 173 ├── -keySize # 密钥长度,必填项,RSA算法的长度为2048/3072/4096,ECC算法的长度NIST-P-256/NIST-P-384 174 ├── -issuer # 颁发者的主题,可选项,如果不填,表示根CA 175 ├── -issuerKeyAlias # 颁发者的密钥别名,可选项,如果不填,表示根CA 176 ├── -issuerKeyPwd # 颁发者的密钥口令,可选项 177 ├── -subject # 证书主题,必填项 178 ├── -validity # 证书有效期,可选项,默认为3650天 179 ├── -signAlg # 签名算法,必填项,包括SHA256withRSA / SHA384withRSA / SHA256withECDSA / SHA384withECDSA 180 ├── -basicConstraintsPathLen # 路径长度,可选项,默认为0 181 ├── -issuerKeystoreFile # 签发者密钥库文件,可选项,JKS或P12格式 182 ├── -issuerKeystorePwd # 签发者密钥库口令,可选项 183 ├── -keystoreFile # 密钥库文件,必填项,JKS或P12格式 184 ├── -keystorePwd # 密钥库口令,可选项 185 ├── -outFile # 输出文件,可选项,如果不填,则直接输出到控制台 186 1874.生成应用调试/发布证书 188 189 generate-app-cert : 生成应用调试/发布证书 190 ├── -keyAlias # 密钥别名,必填项 191 ├── -keyPwd # 密钥口令,可选项 192 ├── -issuer # 颁发者的主题,必填项 193 ├── -issuerKeyAlias # 颁发者的密钥别名,必填项 194 ├── -issuerKeyPwd # 颁发者的密钥口令,可选项 195 ├── -subject # 证书主题,必填项 196 ├── -validity # 证书有效期,可选项,默认为3650天 197 ├── -signAlg # 签名算法,必填项,包括SHA256withECDSA / SHA384withECDSA; 198 ├── -keystoreFile # 密钥库文件,必填项,JKS或P12格式 199 ├── -keystorePwd # 密钥库口令,可选项 200 ├── -issuerKeystoreFile # 签发者密钥库文件,可选项,JKS或P12格式 201 ├── -issuerKeystorePwd # 签发者密钥库口令,可选项 202 ├── -outForm # 输出证书文件的格式,包括 cert / certChain,可选项,默认为certChain 203 ├── -rootCaCertFile # outForm为certChain时必填,根CA证书文件 204 ├── -subCaCertFile # outForm为certChain时必填,中间CA证书文件 205 ├── -outFile # 输出证书文件(证书或证书链),可选项,如果不填,则直接输出到控制台 206 2075.生成profile调试/发布证书 208 209 generate-profile-cert : 生成profile调试/发布证书 210 ├── -keyAlias # 密钥别名,必填项 211 ├── -keyPwd # 密钥口令,可选项 212 ├── -issuer # 颁发者的主题,必填项 213 ├── -issuerKeyAlias # 颁发者的密钥别名,必填项 214 ├── -issuerKeyPwd # 颁发者的密钥口令,可选项 215 ├── -subject # 证书主题,必填项 216 ├── -validity # 证书有效期,可选项,默认为3650天 217 ├── -signAlg # 签名算法,必填项,包括SHA256withECDSA / SHA384withECDSA; 218 ├── -keystoreFile # 密钥库文件,必填项,JKS或P12格式 219 ├── -keystorePwd # 密钥库口令,可选项 220 ├── -issuerKeystoreFile # 签发者密钥库文件,可选项,JKS或P12格式 221 ├── -issuerKeystorePwd # 签发者密钥库口令,可选项 222 ├── -outForm # 输出证书文件的格式,包括 cert / certChain,可选项,默认为certChain 223 ├── -rootCaCertFile # outForm为certChain时必填,根CA证书文件 224 ├── -subCaCertFile # outForm为certChain时必填,中间CA证书文件 225 ├── -outFile # 输出证书文件(证书或证书链),可选项,如果不填,则直接输出到控制台 226 2276.通用证书生成,可以生成自定义证书 228 229 generate-cert : 通用证书生成,可以生成自定义证书 230 ├── -keyAlias # 密钥别名,必填项 231 ├── -keyPwd # 密钥口令,可选项 232 ├── -issuer # 颁发者的主题,必填项 233 ├── -issuerKeyAlias # 颁发者的密钥别名,必填项 234 ├── -issuerKeyPwd # 颁发者的密钥口令,可选项 235 ├── -subject # 证书主题,必填项 236 ├── -validity # 证书有效期,可选项,默认为1095天 237 ├── -keyUsage # 密钥用法,必选项,包括digitalSignature, nonRepudiation, keyEncipherment, 238 ├ dataEncipherment, keyAgreement, certificateSignature, crlSignature, 239 ├ encipherOnly和decipherOnly,如果证书包括多个密钥用法,用逗号分隔 240 ├── -keyUsageCritical # keyUsage是否为关键项,可选项,默认为是 241 ├── -extKeyUsage # 扩展密钥用法,可选项,包括clientAuthentication,serverAuthentication, 242 ├ codeSignature,emailProtection,smartCardLogin,timestamp,ocspSignature 243 ├── -extKeyUsageCritical # extKeyUsage是否为关键项,可选项,默认为否 244 ├── -signAlg # 签名算法,必填项,包括SHA256withRSA/SHA384withRSA/SHA256withECDSA/SHA384withECDSA 245 ├── -basicConstraints # 是否包含basicConstraints,可选项,默认为否 246 ├── -basicConstraintsCritical # basicConstraints是否包含为关键项,可选项,默认为否 247 ├── -basicConstraintsCa # 是否为CA,可选项,默认为否 248 ├── -basicConstraintsPathLen # 路径长度,可选项,默认为0 249 ├── -issuerKeystoreFile # 签发者密钥库文件,可选项,JKS或P12格式 250 ├── -issuerKeystorePwd # 签发者密钥库口令,可选项 251 ├── -keystoreFile # 密钥库文件,必填项,JKS或P12格式 252 ├── -keystorePwd # 密钥库口令,可选项 253 ├── -outFile # 输出证书文件,可选项,如果不填,则直接输出到控制台 254 2557.ProvisionProfile文件签名 256 257 sign-profile : ProvisionProfile文件签名 258 ├── -mode # 签名模式,必填项,包括localSign,remoteSign 259 ├── -keyAlias # 密钥别名,必填项 260 ├── -keyPwd # 密钥口令,可选项 261 ├── -profileCertFile # Profile签名证书(证书链,顺序为最终实体证书-中间CA证书-根证书),必填项 262 ├── -inFile # 输入的原始Provision Profile文件,必填项 263 ├── -signAlg # 签名算法,必填项,包括SHA256withECDSA / SHA384withECDSA 264 ├── -keystoreFile # 密钥库文件,localSign模式时为必填项,JKS或P12格式 265 ├── -keystorePwd # 密钥库口令,可选项 266 ├── -outFile # 输出签名后的Provision Profile文件,p7b格式,必填项 267 2688.ProvisionProfile文件验签 269 270 verify-profile : ProvisionProfile文件验签 271 ├── -inFile # 已签名的Provision Profile文件,p7b格式,必填项 272 ├── -outFile # 验证结果文件(包含验证结果和profile内容),json格式,可选项;如果不填,则直接输出到控制台 273 2749.hap应用包签名 275 276 sign-app : hap应用包签名 277 ├── -mode # 签名模式,必填项,包括localSign,remoteSign,remoteResign 278 ├── -keyAlias # 密钥别名,必填项 279 ├── -keyPwd # 密钥口令,可选项 280 ├── -appCertFile # 应用签名证书文件(证书链,顺序为最终实体证书-中间CA证书-根证书),必填项 281 ├── -profileFile # 签名后的Provision Profile文件名,profileSigned为1时为p7b格式,profileSigned为0时为json格式,必填项 282 ├── -profileSigned # 指示profile文件是否带有签名,1表示有签名,0表示没有签名,默认为1。可选项 283 ├── -inForm # 输入的原始文件的格式,zip格式或bin格式,默认zip格式,可选项 284 ├── -inFile # 输入的原始APP包文件,zip格式或bin格式,必填项 285 ├── -signAlg # 签名算法,必填项,包括SHA256withECDSA / SHA384withECDSA 286 ├── -keystoreFile # 密钥库文件,localSign模式时为必填项,JKS或P12格式 287 ├── -keystorePwd # 密钥库口令,可选项 288 ├── -outFile # 输出签名后的包文件,必填项 289 29010.hap应用包文件验签 291 292 verify-app : hap应用包文件验签 293 ├── -inFile # 已签名的应用包文件,zip格式或bin格式,必填项 294 ├── -outCertChain # 签名的证书链文件,必填项 295 ├── -outProfile # 应用包中的profile文件,必填项 296 297 298 299 300#### 相关仓 301 不涉及