Android部署打包apk应用,需要用上数字证书进行签名,来表明身份的。
说到苹果证书,那是要收费的。而安卓证书恰恰相反,免费又不需要审批。
安卓证书可以使用Java的keytool工具生成,以下是window平台生成的方法:
安装java(已安装的跳过)
可访问Oracle官方去安装java:https://www.java.com/zh_CN/download/win10.jsp
下面已安装目录“C:Program Files (x86)Javajdk1.8.0_73”为例,实际操作请修改自己的安装目录
安装java完成后,打开安装目录,找到bin文件夹,如果里面有keytool.exe这个文件,那么下面的安卓证书就能搞了
生成签名证书
在“C:Program Files (x86)Javajdk1.8.0_73in”目录下,打开终端,使用keytool工具的-genkey命令生成证书(如果你配置了系统变量,可以直接使用keytool命令,就没必要和我一样输入相对路径“./keytool.exe”)
./keytool.exe -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore
testalias是证书别名,可修改为自己想设置的字符,建议使用英文字母和数字
test.keystore是证书文件名称,可修改为自己想设置的文件名称,也可以指定完整文件路径
Enter后会提示:
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): //确认证书密码与证书文件密码一样,直接回车就可以
以上的命令运行完成后,在当前目录下(C:Program Files (x86)Javajdk1.8.0_73in)会有一个test.keystore文件生成
查看证书信息
可以用以下命令查看:
./keytool.exe -list -v -keystore test.keystore Enter keystore password: //输入密码,Enter
会输出以下格式信息:
密钥库类型: JKS 密钥库提供方: SUN 您的密钥库包含 1 个条目 别名: testalias 创建日期: 2020-5-22 条目类型: PrivateKeyEntry 证书链长度: 1 证书[1]: 所有者: CN=murenziwei, OU=web, O=个人, L=神之领域, ST=天庭, C=CN 发布者: CN=murenziwei, OU=web, O=个人, L=神之领域, ST=天庭, C=CN 序列号: 1bfbc40a 有效期开始日期: Fri May 22 15:11:17 CST 2020, 截止日期: Sun Apr 28 15:11:17 CST 2120 证书指纹: MD5: E6:FB:23:EB:BF:C3:D0:0D:94:36:DE:E2:76:E0:1A:F5 SHA1: FE:1D:71:B2:1F:3F:AE:E8:CB:E4:A4:DE:05:B9:D7:49:BA:50:41:0D SHA256: 7B:17:60:8A:B4:0C:3C:8F:E6:98:75:5A:61:E0:54:BC:EA:32:EB:22:CF:19:49:04:C8:CF:25:1E:1C:88:5B:ED 签名算法名称: SHA256withRSA 版本: 3 扩展: #1: ObjectId: 2.5.29.14 Criticality=false SubjectKeyIdentifier [ KeyIdentifier [ 0000: E8 52 AA 7D 17 3D F4 DB 1E EC 14 D2 C6 F0 A7 52 .R...=.........R 0010: 16 E5 36 FF ..6. ] ] ******************************************* *******************************************
其中的证书指纹信息:
MD5
证书的MD5指纹信息(安全码MD5)
证书的MD5指纹信息(安全码MD5)
SHA1
证书的SHA1指纹信息(安全码SHA1)
证书的SHA1指纹信息(安全码SHA1)
SHA256
证书的SHA256指纹信息(安全码SHA245)
证书的SHA256指纹信息(安全码SHA245)