tomcat构建HTTPS双向认证

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了tomcat构建HTTPS双向认证相关的知识,希望对你有一定的参考价值。

第一步:为服务器生成证书

# keytool -genkey -alias tomcat -keyalg RSA -keystore /usr/local/ac/web/tomcat.keystore -validity 36500

 

(参数简要说明:“/etc/tomcat.keystore”含义是将证书文件保存在路径/usr/local/ac/web/下,证书文件名称是tomcat.keystore ;“-validity 36500”含义是证书有效期,36500表示100年,默认值是90天)

 

 

第二步:为客户端生成证书

为浏览器生成证书,以便让服务器来验证它。为了能将证书顺利导入至IE和Firefox,证书格式应该是PKCS12,因此,使用如下命令生成:

 

keytool -genkey -v -alias mykey -keyalg RSA -storetype PKCS12 -keystore /home/mykey.p12

 

双击mykey.p12文件,即可将证书导入至浏览器(客户端)。

 

第三步:让服务器信任客户端证书

由于是双向SSL认证,服务器必须要信任客户端证书,因此,必须把客户端证书添加为服务器的信任认证。由于不能直接将PKCS12格式的证书库导入,必须先把客户端证书导出为一个单独的CER文件,使用如下命令:

 

keytool -export -alias mykey -keystore /home/mykey.p12 -storetype PKCS12 -storepass password -rfc -file /home/mykey.cer

 

将该文件导入到服务器的证书库,添加为一个信任证书:

keytool -import -v -file /home/mykey.cer -keystore /home/tomcat.keystore

 

通过list命令查看服务器的证书库

keytool -list -keystore  tomcat.keystore

 

第四步:让客户端信任服务器证书

由于是双向SSL认证,客户端也要验证服务器证书,因此,必须把服务器证书添加到浏览的“受信任的根证书颁发机构”。由于不能直接将keystore格式的证书库导入,必须先把服务器证书导出为一个单独的CER文件,使用如下命令:

 

keytool -keystore tomcat.keystore -export -alias tomcat -file tomcat.cer

 

双击tomcat.cer文件,按照提示安装证书,将证书填入到“受信任的根证书颁发机构”。

 

步:配置Tomcat服务器

 

打开Tomcat根目录下的/conf/server.xml,找到如下配置段,修改如下:

 

<Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
SSLEnabled="true" maxThreads="150" scheme="https"
secure="true" clientAuth="true" sslProtocol="TLS"
keystoreFile="test.keystore" keystorePass="123456"
truststoreFile="test.keystore" truststorePass="123456" />

 

属性说明:

· clientAuth:设置是否双向验证,默认为false,设置为true代表双向验证

· keystoreFile:服务器证书文件路径

· keystorePass:服务器证书密码

· truststoreFile:用来验证客户端证书的根证书,此例中就是服务器证书

· truststorePass:根证书密码

 

 

步:测试

 

在浏览器中输入:

https://localhost:8443/,会弹出选择客户端证书界面,点击“确定”,会进入tomcat主页,地址栏后会有“锁”图标,表示本次会话已经通过HTTPS双向验证,接下来的会话过程中所传输的信息都已经过SSL信息加密。


操作命令:

#  keytool -genkey -alias tomcat -keyalg RSA -keystore /root/zhengshu/tomcat.keystore -validity 36500


#  keytool -genkey -alias tomcat -keyalg RSA -keystore /root/zhengshu/tomcat.keystore -validity 36500


#  keytool -genkey -v -alias mykey -keyalg RSA -storetype PKCS12 -keystore /root/zhengshu/mykey.p12 -validity 36500


#  keytool -export -alias mykey -keystore /root/zhengshu/mykey.p12 -storetype PKCS12 -storepass password -rfc -file /root/zhengshu/mykey.cer


#  keytool -import -v -file /root/zhengshu/mykey.cer -keystore /root/zhengshu/tomcat.keystore

#  keytool -list -keystore  tomcat.keystore

#  keytool -keystore tomcat.keystore -export -alias tomcat -file tomcat.cer


以上是关于tomcat构建HTTPS双向认证的主要内容,如果未能解决你的问题,请参考以下文章

Tomcat容器https配置之双向认证

实现tomcat的https单向认证及双向认证

keytool+tomcat配置HTTPS双向证书认证

利用tomcat服务器配置https双向认证

tomcat8.5之后怎么配置https双向认证

HTTPS双向认证