Android部署打包apk应用,需要用上数字证书进行签名,来表明身份的。
说到苹果证书,那是要收费的。而安卓证书恰恰相反,免费又不需要审批。
安卓证书可以使用Java的keytool工具生成,以下是window平台生成的方法:
安装java(已安装的跳过)
下面已安装目录“C:\Program Files (x86)\Java\jdk1.8.0_73”为例,实际操作请修改自己的安装目录
安装java完成后,打开安装目录,找到bin文件夹,如果里面有keytool.exe这个文件,那么下面的安卓证书就能搞了
生成签名证书
在“C:\Program Files (x86)\Java\jdk1.8.0_73\bin”目录下,打开终端,使用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
(RETURN if same as keystore password): //确认证书密码与证书文件密码一样,直接回车就可以
以上的命令运行完成后,在当前目录下(C:\Program Files (x86)\Java\jdk1.8.0_73\bin)会有一个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)
SHA1
证书的SHA1指纹信息(安全码SHA1)
SHA256
证书的SHA256指纹信息(安全码SHA245)