1、下载Android Studio
下载地址:Android 开发者 | Android Developers
2、下载android SDK
下载地址:原生开发者支持
3、解压android SDK->查看release.md文件->检查当前HBuilderX与指定打包版本是否一样->更新HBuilderX到对应版本
3.1 解压android SDK文件如下
3.2 查看release.md中版本
3.3 查看HBuilderX版本(若不对应,请更新或者想办法HBulderX至对应版本)
4、保证版本一致后,HbuilderX中打开自己项目:发行->原生app-本地打包(L)->生成本地打包app资源(R)
5、Android Studio打开解压完成的android SDK文件中第一个文件:离线打包演示应用
6、替换离线打包演示应用:Hbuilder-HelloUniApp->app->src->main->assets->apps目录下的文件夹替换成自己uniapp项目下->unpackage->resources下面的以你appid命名的文件夹
7、确保以下文件appid一致(打了红线的应该都是一样的)
Ⅰ:
Ⅱ:
Ⅲ:
8、登录开发者中心:登录->我创建的应用->点击对应应用名称
登录链接:DAccount Service
8.1 离线打包key管理:配置对应信息
8.2 android配置:Android 包名: 项目中生成的包名(打开的android studio项目下app->src->build.gradle的applicationId)
8.3 android配置:Android 证书签名SHA1:通过以下操作生成SHA1
Android平台签名证书生成指南链接:Android平台签名证书(.keystore)生成指南 - DCloud问答
(注:整个8.3步骤与上面的生成指南一样,可忽略:))
cmd打开命令提示符窗口
安装JRE环境(C:\Program Files\Java\jdk1.8.0_221\bin为我自己jre安装目录)
输入:d:
输入:set PATH=%PATH%;"C:\Program Files\Java\jdk1.8.0_221\bin"
- 第一行:切换工作目录到D:路径
- 第二行:将jre命令添加到临时环境变量中
生成签名证书
使用keytool -genkey命令生成证书:
keytool -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore
- testalias是证书别名,可修改为自己想设置的字符,建议使用英文字母和数字
- test.keystore是证书文件名称,可修改为自己想设置的文件名称,也可以指定完整文件路径
- 36500是证书的有效期,表示100年有效期,单位天,建议时间设置长一点,避免证书过期
回车后会提示:
Enter keystore password: //输入证书文件密码,输入完成回车
Re-enter new password: //再次输入证书文件密码,输入完成回车
What is your first and last name?
[Unknown]: //输入名字和姓氏,输入完成回车
What is the name of your organizational unit?
[Unknown]: //输入组织单位名称,输入完成回车
What is the name of your organization?
[Unknown]: //输入组织名称,输入完成回车
What is the name of your City or Locality?
[Unknown]: //输入城市或区域名称,输入完成回车
What is the name of your State or Province?
[Unknown]: //输入省/市/自治区名称,输入完成回车
What is the two-letter country code for this unit?
[Unknown]: //输入国家/地区代号(两个字母),中国为CN,输入完成回车
Is CN=XX, OU=XX, O=XX, L=XX, ST=XX, C=XX correct?
[no]: //确认上面输入的内容是否正确,输入y,回车
Enter key password for <testalias>
(RETURN if same as keystore password): //确认证书密码与证书文件密码一样(HBuilder|HBuilderX要求这两个密码一致),直接回车就可以
以上命令运行完成后就会生成证书,路径为“D:\test.keystore”。
查看证书信息
可以使用以下命令查看:
keytool -list -v -keystore test.keystore
Enter keystore password: //输入密码,回车
会输出以下格式信息:
Keystore type: PKCS12
Keystore provider: SUN
Your keystore contains 1 entry
Alias name: test
Creation date: 2019-10-28
Entry type: PrivateKeyEntry
Certificate chain length: 1
Certificate[1]:
Owner: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN
Issuer: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN
Serial number: 7dd12840
Valid from: Fri Jul 26 20:52:56 CST 2019 until: Sun Jul 02 20:52:56 CST 2119
Certificate fingerprints:
MD5: F9:F6:C8:1F:DB:AB:50:14:7D:6F:2C:4F:CE:E6:0A:A5
SHA1: BB:AC:E2:2F:97:3B:18:02:E7:D6:69:A3:7A:28:EF:D2:3F:A3:68:E7
SHA256: 24:11:7D:E7:36:12:BC:FE:AF:2A:6A:24:BD:04:4F:2E:33:E5:2D:41:96:5F:50:4D:74:17:7F:4F:E2:55:EB:26
Signature algorithm name: SHA256withRSA
Subject Public Key Algorithm: 2048-bit RSA key
Version: 3
其中证书指纹信息(Certificate fingerprints):
- MD5
证书的MD5指纹信息(安全码MD5) - SHA1
证书的SHA1指纹信息(安全码SHA1) - SHA256
证书的SHA256指纹信息(安全码SHA245)
本人的以上操作后结果如下:
8.4 android配置:填写完 包名和SHA1 后保存生成android appkey
9、将安卓许可证书(***.keystore)test.keystore放在app的根目录下
10、修改android studio项目app下build.gradle中的signingConfigs
11、修改android studio项目下app->src->main中AndroidManifest.xml文件的appkey为上面生成的
12、打包生成apk
参考学习链接:手摸手实现uni-app安卓本地打包_Leo Tang的博客-CSDN博客_uniapp本地打包和云打包
参考学习链接:uniapp Android 离线打包之未配置appkey或配置错误_Good night �的博客-CSDN博客_未配置appkey或配置错误
菜鸟第一次尝试写学习记录,如有错误,望大佬多多海涵,不吝赐教,O(∩_∩)O谢谢