<返回更多

程序员必备工具 Java证书工具Keytool的使用

2020-07-31    
加入收藏
程序员必备工具 Java证书工具Keytool的使用

 

一、简介

Keytool是JDK自带的证书管理工具,在jdk/bin目录下,可以用来生成自签名证书、导入导出证书、打印证书信息等。

回顾下前一章的一些概念:

二、Java证书工具Keytool的使用

2.1 生成自签名证书.jks

创建一个名为myjks的证书,存放在teststore.jks的密钥库中。

keytool -genkeypair  -alias myjks -keysize 2048 -keyalg RSA -validity 3650 -keystore teststore.jks -storetype JKS 
程序员必备工具 Java证书工具Keytool的使用

 

2.2 导出自签名证书

keytool -export -alias myjks -keystore teststore.jks -file myjks.crt
程序员必备工具 Java证书工具Keytool的使用

 

这个证书就可以分发给客户端使用。

2.2 查看证书信息

keytool -list -v -keystore teststore.jks
程序员必备工具 Java证书工具Keytool的使用

 

2.3 显示证书内容

keytool -list -rfc -keystore teststore.jks -storepass 12345678
程序员必备工具 Java证书工具Keytool的使用

 

2.4 导出cer证书

keytool -alias myjks -exportcert -keystore teststore.jks -file teststore.cer
程序员必备工具 Java证书工具Keytool的使用

 

双击证书,可以查看cer内容,点安装证书就可以导入根证书。

程序员必备工具 Java证书工具Keytool的使用

 

2.5 导出公钥

keytool -list -rfc --keystore teststore.jks | openssl x509 -inform pem -pubkey
程序员必备工具 Java证书工具Keytool的使用

 

三、生成一个根证书来签发二级证书

3.1 生成证书签名请求文件CSR

keytool -certreq -alias myjks -keystore teststore.jks -file teststore.csr
程序员必备工具 Java证书工具Keytool的使用

 

3.2 使用自签名证书作为CA根证书,模拟CA给CSR签发证书

生成模拟CA的密钥对

keytool -genkeypair -alias rootca -keysize 2048 -keyalg RSA -validity 3650 -keystore rootstore.jks -storetype JKS
程序员必备工具 Java证书工具Keytool的使用

 

keytool -gencert -alias rootca -keystore rootstore.jks -infile teststore.csr -outfile teststore_new.crt
程序员必备工具 Java证书工具Keytool的使用

 

可以看到teststore_new.crt的签发人已经变了:

程序员必备工具 Java证书工具Keytool的使用

 

3.3 将二级证书导回teststore库中

keytool -import -v -alias rootca -file teststore_new.crt -keystore teststore.jks
程序员必备工具 Java证书工具Keytool的使用

 

这时证书链会发生变化 :

keytool -list -v -keystore teststore.jks
程序员必备工具 Java证书工具Keytool的使用

 

这时可以把root证书导出给客户端内置,服务端绑定二级证书,这样客户端验证时可以用根证书验证二级证书。大部分程序直接使用一级的自签名证书即可,但若需要双向验证,服务端验证客户端时不同客户端最好使用服务端的rootca私钥来签发,这样服务端可以直接用一个rootca的证书验证。实现了动态扩展且客户端的证书不同。

3.4 从teststore导出rootca证书

keytool -export -alias rootca -keystore teststore.jks -file rootca.crt
程序员必备工具 Java证书工具Keytool的使用

 

四、Keytool其它常用命令

// 以rfc模式打印,即base64可见字符,与pem编码格式一样。 -v为详细输出
keytool -printcert -rfc -file rootca.crt

// 删除密钥库中的条目
keytool -delete -alias rootca -keystore teststore.keystore

// 修改证书库密码,输入旧密码或加参数 -storepass 111111
keytool -storepasswd -new 123456 -keystore truststore

// 修改某条目密码
keytool -keypasswd -alias myCA -keypass 654321 -new newpass -storepass 123456 -keystore myCALib
声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>