一、   生成证书请求


1.  安装JDK

安装Tomcat需要JDK支持。如果您还没有JDK的安装,则可以参考

Java SE Development Kit (JDK) 下载。下载地址:

​http://www.oracle.com/technetwork/java/javase/downloads/index.html​​​


2.  生成keystore文件

生成密钥库文件keystore.jks需要使用JDK的keytool工具。命令行进入JDK或JRE下的bin目录,运行keytool命令(示例中粗体部分为可自定义部分,请根据实际配置情况作相应调整)。

keytool -genkey -alias ​server​ -keyalg RSA -keysize 2048 -keystore keystore.jks -storepass​password​ -keypass ​password

服务器证书安装配置指南(Tomcat 6)_客户端


以上命令中,server为私钥别名(-alias),生成的keystore.jks文件默认放在命令行当前路径下。


3.  生成证书请求文件(CSR)

keytool -certreq -alias server -sigalg SHA1withRSA -file certreq.csr -keystore C:\keystore.jks -keypass​password​ -storepass ​password

服务器证书安装配置指南(Tomcat 6)_服务器_02


备份密钥库文件keystore.jks,并稍后提交证书请求文件certreq.csr,等待证书签发。密钥库文件keystore.jks丢失将导致证书不可用。


二、  导入服务器证书


1.  获取服务器证书中级CA证书

为保障服务器证书在客户端的兼容性,服务器证书需要安装两张中级CA证书(不同品牌证书,可能只有一张中级证书)。

邮件中获取中级CA证书:

将证书签发邮件中的从BEGIN到 END结束的两张中级CA证书内容(包括“-----BEGIN CERTIFICATE-----”和“-----END CERTIFICATE-----”)分别粘贴到记事本等文本编辑器中,并修改文件扩展名,保存为intermediate1.cer和intermediate2.cer文件。


2.  获取服务器证书

将证书签发邮件中的从BEGIN到 END结束的服务器证书内容(包括“-----BEGIN CERTIFICATE-----”和“-----END CERTIFICATE-----”)粘贴到记事本等文本编辑器中,并修改文件扩展名,保存为server.cer文件


3.  查看Keystore文件内容

进入JDK安装目录下的bin目录,运行keytool命令。

keytool -list -keystore keystore.jks -storepass ​ password

服务器证书安装配置指南(Tomcat 6)_服务器_03


查询到PrivateKeyEntry属性的私钥别名(alias)为server。记住该别名,在稍后导入服务器证书时需要用到(示例中粗体部分为可自定义部分,请根据实际配置情况作相应调整)。

注意,导入证书时,一定要使用生成证书请求文件时生成的keystore.jks文件。keystore.jks文件丢失或生成新的keystore.jks文件,都将无法正确导入您的服务器证书。


4.  导入证书(如果只有一张中级证书,则只需要导入一张中级证书)

导入第一张中级CA证书

keytool -import -alias intermediate1 -keystore keystore.jks -trustcacerts -storepass​password​ -file intermediate1.cer

导入第二张中级CA证书

keytool -import -alias intermediate2 -keystore keystore.jks -trustcacerts -storepass​password​ -file intermediate2.cer

服务器证书安装配置指南(Tomcat 6)_客户端_04


导入服务器证书

keytool -import -alias server -keystore C:\keystore.jks -trustcacerts -storepass​password​ -file server.cer

服务器证书安装配置指南(Tomcat 6)_客户端_05


导入服务器证书时,服务器证书的别名必须和私钥别名一致。请留意导入中级CA证书和导入服务器证书时的提示信息,如果您在导入服务器证书时使用的别名与私钥别名不一致,将提示“认证已添加至keystore中”而不是应有的“认证回复已安装在keystore中”。

证书导入完成,运行keystool命令,再次查看keystore文件内容

keytool -list -keystore keystore.jks -storepass ​ password

 服务器证书安装配置指南(Tomcat 6)_服务器_06



三、  安装服务器证书


1.  单向认证的配置


复制已正确导入认证回复的keystore.jks文件到Tomcat安装目录下的conf目录。打开conf目录下的server.xml文件,找到并修改以下内容


    <!--


    <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"


               maxThreads="150" scheme="https" secure="true"


               clientAuth="false" sslProtocol="TLS" />


SSL访问端口


    -->


修改为


    <Connector port="443" protocol="org.apache.coyote.http11.Http11Protocol" SSLEnabled="true"


               maxThreads="150" scheme="https" secure="true"


               keystoreFile="conf\keystore.jks" keystorePass="password"


               clientAuth="false" sslProtocol="TLS" />


默认的SSL访问端口号为443,如果使用其他端口号,则您需要使用https://yourdomain:port的方式来访问您的站点。



2.  双向认证的配置


配置双向认证时,您还需要指定客户端认证的信任库文件。客户端认证信任库文件(truststoreFile)可以和服务器证书密钥库文件(keystoreFile)为同一个文件,也可以进行独立配置。


示例中使用相同的密钥库文件。您需要首先将客户端认证的根证书以及中级CA证书导入到客户端认证信任库。


    <Connector port="443" protocol="org.apache.coyote.http11.Http11Protocol" SSLEnabled="true"


               maxThreads="150" scheme="https" secure="true"


               keystoreFile="conf\keystore.jks" keystorePass="password"


               truststoreFile="conf\keystore.jks" truststorePass="password"


               clientAuth="true" sslProtocol="TLS" />



3.  访问测试


重启Tomcat,访问https://youdomain:port,测试证书的安装。


Linux 操作一样步骤一样。