Android部署打包apk应用,需要用上数字证书进行签名,来表明身份的。

说到苹果证书,那是要收费的。而安卓证书恰恰相反,免费又不需要审批。

安卓证书可以使用Java的keytool工具生成,以下是window平台生成的方法:

安装java(已安装的跳过)

下面已安装目录“C:\Program Files (x86)\Java\jdk1.8.0_73”为例,实际操作请修改自己的安装目录

安装java完成后,打开安装目录,找到bin文件夹,如果里面有keytool.exe这个文件,那么下面的安卓证书就能搞了

java 验证证书签名 java自签名证书_Java

生成签名证书

在“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)