扫描二维码关注官方公众号
返回列表 发布新帖

[安卓] Android平台签名证书(.keystore)生成指南

182 0
发表于 2024-10-5 12:10:31| 字数 3,076 | 查看全部 阅读模式 来自 中国
Android平台打包发布apk应用,需要使用数字证书(.keystore文件)进行签名,用于表明开发者身份。
Android证书的生成是自助和免费的,不需要审批或付费。
可以使用JRE环境中的keytool命令生成。以下是windows平台生成证书的方法:
安装JRE环境(推荐使用JRE8环境,如已有可跳过)
可从Oracle官方下载jre安装包:https://www.oracle.com/java/technologies/downloads/#java8
下面以Windows平台,jre安装目录为“C:\Program Files\Java\jre1.8.0_201”为例,实际操作时请修改为自己安装目录
建议将JRE安装路径添加到系统环境变量,已配置可跳过此章节
打开命令行(cmd),输入以下命令:
  1. d:set PATH=%PATH%;"C:\Program Files\Java\jre1.8.0_201\bin"
复制代码
  • 第一行:切换工作目录到D:路径
  • 第二行:将jre命令添加到临时环境变量中
生成签名证书
使用keytool -genkey命令生成证书:
  1. keytool -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore
复制代码

  • testalias是证书别名,可修改为自己想设置的字符,建议使用英文字母和数字
  • test.keystore是证书文件名称,可修改为自己想设置的文件名称,也可以指定完整文件路径
  • 36500是证书的有效期,表示100年有效期,单位天,建议时间设置长一点,避免证书过期
回车后会提示:
  1. Enter keystore password:  //输入证书文件密码,输入完成回车  
  2. Re-enter new password:   //再次输入证书文件密码,输入完成回车  
  3. What is your first and last name?  
  4.   [Unknown]:  //输入名字和姓氏,输入完成回车  
  5. What is the name of your organizational unit?  
  6.   [Unknown]:  //输入组织单位名称,输入完成回车  
  7. What is the name of your organization?  
  8.   [Unknown]:  //输入组织名称,输入完成回车  
  9. What is the name of your City or Locality?  
  10.   [Unknown]:  //输入城市或区域名称,输入完成回车  
  11. What is the name of your State or Province?  
  12.   [Unknown]:  //输入省/市/自治区名称,输入完成回车  
  13. What is the two-letter country code for this unit?  
  14.   [Unknown]:  //输入国家/地区代号(两个字母),中国为CN,输入完成回车  
  15. Is CN=XX, OU=XX, O=XX, L=XX, ST=XX, C=XX correct?  
  16.   [no]:  //确认上面输入的内容是否正确,输入y,回车  

  17. Enter key password for <testalias>  
  18.         (RETURN if same as keystore password):  //确认证书密码与证书文件密码一样(HBuilder|HBuilderX要求这两个密码一致),直接回车就可以
复制代码

以上命令运行完成后就会生成证书,路径为“D:\test.keystore”。
注意:上述信息填写要规范,乱填有可能会影响应用上架应用市场。

查看证书信息
可以使用以下命令查看:
  1. keytool -list -v -keystore test.keystore  
  2. Enter keystore password: //输入密码,回车
复制代码

会输出以下格式信息:
  1. Keystore type: PKCS12   
  2. Keystore provider: SUN   

  3. Your keystore contains 1 entry   

  4. Alias name: test   
  5. Creation date: 2019-10-28   
  6. Entry type: PrivateKeyEntry   
  7. Certificate chain length: 1   
  8. Certificate[1]:   
  9. Owner: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN   
  10. Issuer: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN   
  11. Serial number: 7dd12840   
  12. Valid from: Fri Jul 26 20:52:56 CST 2019 until: Sun Jul 02 20:52:56 CST 2119   
  13. Certificate fingerprints:   
  14.          MD5:  F9:F6:C8:1F:DB:AB:50:14:7D:6F:2C:4F:CE:E6:0A:A5   
  15.          SHA1: BB:AC:E2:2F:97:3B:18:02:E7:D6:69:A3:7A:28:EF:D2:3F:A3:68:E7   
  16.          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   
  17. Signature algorithm name: SHA256withRSA   
  18. Subject Public Key Algorithm: 2048-bit RSA key   
  19. Version: 3
复制代码

其中证书指纹信息(Certificate fingerprints):
  • MD5
    证书的MD5指纹信息(安全码MD5)
  • SHA1
    证书的SHA1指纹信息(安全码SHA1)
  • SHA256
    证书的SHA256指纹信息(安全码SHA245)
安卓签名获取工具
直接通过一个apk,获取安装到手机的第三方应用签名的apk包。 详情:https://developers.weixin.qq.com/doc/oplatform/Downloads/Android_Resource.html
注意事项
云端打包默认会添加V1/V2签名,已知V1签名不支持2048位的DSA算法,使用2048-bit DSA key云端打包可能失败,提示以下错误:
  1. * What went wrong:  
  2. Execution failed for task ':app:packageRelease'.  
  3. > A failure occurred while executing com.android.build.gradle.tasks.PackageAndroidArtifact$IncrementalSplitterRunnable  
  4.    > java.io.IOException: Failed to generate v1 signature
复制代码

解决方法
  • 第一种方法:重新生成证书,在生成证书命令中添加“-keyalg RSA”参数指定使用RSA算法
  • 第二种方法:设置miniSdkVersion大于等于24,因为V2签名需Android7及以上设备才支持,设置miniSdkVersion大于等于24表示不支持android7以下设备,从而不需要包含V1签名,设置miniSdkVersion详情参考:https://ask.dcloud.net.cn/article/193
查看证书算法的方法
使用“keytool -list -v”查看证书信息,看“Subject Public Key Algorithm: ”项的信息,如下表示使用DSA算法:
  1. Subject Public Key Algorithm: 2048-bit DSA key
复制代码

免责声明

信息及内容: 内容仅代表用户个人观点,与本论坛无关。本论坛不保证内容的准确性、完整性或时效性,使用请自行判断和承担风险。

法律责任: 用户对其发布内容负全责,包括但不限于版权、隐私、诽谤等。因使用本论坛内容导致的任何损失,本论坛不承担责任。

版权与隐私: 请勿发布侵犯他人版权或涉及隐私的信息。发现侵权行为,请立即联系我们处理。

第三方链接及广告: 本论坛不对第三方网站或资源的内容负责。用户因访问或使用第三方内容或广告进行的交易和产生的损失,本论坛不承担责任。

用户行为: 用户需遵守论坛规则和法律法规,不得发布违法、侮辱性或不恰当内容。我们有权删除违反规则的内容并采取相应措施。

联系我们: 如有疑问或发现违规行为,请联系管理员:865817711@qq.com

回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

投诉/建议联系

865817711@qq.com

未经授权禁止转载,复制和建立镜像,
如有违反,追究法律责任
  • 关注公众号
  • 添加微信客服
Copyright © 2001-2025 第一论坛网 版权所有 All Rights Reserved. 浙ICP备2023009069号-17|浙公网安备33010602013740号
关灯 在本版发帖
扫一扫添加微信客服
QQ客服返回顶部
快速回复 返回顶部 返回列表