tomcat 啟用https協議


利用tomcat服務器配置https雙向認證。

1、為服務器生成證書

打開cmd,進入jdk的bin目錄下,輸入下面的命令:

1 keytool -genkey -v -alias tomcat -keyalg RSA -keystore D:\homes\tomcat.keystore -validity 36500

命令解釋:

  使用keytool為Tomcat生成證書,假定目標機器的域名是“localhost”,keystore文件想要存放在“D:\homes\tomcat.keystore”,口令為“123123”。

參數簡要說明:

  “D:\homes\tomcat.keystore”含義是將證書文件的保存路徑,證書文件名稱是tomcat.keystore ;“-validity 36500”含義是證書有效期,36500表示100年,默認值是90天 “tomcat”為自定義證書名稱。

根據提示進行遷移,命令為:

 

1 keytool -importkeystore -srckeystore D:\homes\tomcat.keystore -destkeystore D:\homes\tomcat.keystore -deststoretype pkcs12

 

在命令行填寫必要參數:

A、 輸入keystore密碼:此處需要輸入大於6個字符的字符串。
B、 “您的名字與姓氏是什么?”這是必填項,並且必須是TOMCAT部署主機的域名或者IP[如:gbcom.com 或者 10.1.25.251](就是你將來要在瀏覽器中輸入的訪問地址),否則瀏覽器會彈出警告窗口,提示用戶證書與所在域不匹配。在本地做開發測試時,應填入“localhost”。
C、 你的組織單位名稱是什么?”、“您的組織名稱是什么?”、“您所在城市或區域名稱是什么?”、“您所在的州或者省份名稱是什么?”、“該單位的兩字母國家代碼是什么?”可以按照需要填寫也可以不填寫直接回車,在系統詢問“正確嗎?”時,對照輸入信息,如果符合要求則使用鍵盤輸入字母“y”,否則輸入“n”重新填寫上面的信息。
D、 輸入<tomcat>的主密碼,這項較為重要,會在tomcat配置文件中使用,建議輸入與keystore的密碼一致,設置其它密碼也可以,完成上述輸入后,直接回車則在你在第二步中定義的位置找到生成的文件。

2、為客戶端生成證書
為瀏覽器生成證書,以便讓服務器來驗證它。為了能將證書順利導入至IE和Firefox,證書格式應該是PKCS12,因此,使用如下命令生成:

1 keytool -genkey -v -alias mykey -keyalg RSA -storetype PKCS12 -keystore D:\homes\mykey.p12

(mykey為自定義)。

對應的證書庫存放在“D:\homes\mykey.p12”,客戶端的CN可以是任意值。雙擊mykey.p12文件,輸入剛才設置的密碼,即可將證書導入至瀏覽器(客戶端)。

3、讓服務器信任客戶端證書

  由於是雙向SSL認證,服務器必須要信任客戶端證書,因此,必須把客戶端證書添加為服務器的信任認證。由於不能直接將PKCS12格式的證書庫導入,必須先把客戶端證書導出為一個單獨的CER文件,使用如下命令:

1 keytool -export -alias mykey -keystore D:\homes\mykey.p12 -storetype PKCS12 -storepass 123123 -rfc -file D:\homes\mykey.cer 

(mykey為自定義與客戶端定義的mykey要一致,password是你設置的密碼)。通過以上命令,客戶端證書就被我們導出到“D:\home\mykey.cer”文件了。

下一步,是將該文件導入到服務器的證書庫,添加為一個信任證書使用命令如下:

1 keytool -import -v -file D:\homes\mykey.cer -keystore D:\homes\tomcat.keystore

通過list命令查看服務器的證書庫,可以看到兩個證書,一個是服務器證書,一個是受信任的客戶端證書:

(tomcat為你設置服務器端的證書名)。

4、讓客戶端信任服務器證書

  由於是雙向SSL認證,客戶端也要驗證服務器證書,因此,必須把服務器證書添加到瀏覽的“受信任的根證書頒發機構”。由於不能直接將keystore格式的證書庫導入,必須先把服務器證書導出為一個單獨的CER文件,使用如下命令:

1 keytool -keystore D:\home\tomcat.keystore -export -alias tomcat -file D:\home\tomcat.cer

 (tomcat為你設置服務器端的證書名)。

  通過以上命令,服務器證書就被我們導出到“D:\homes\tomcat.cer”文件了。雙擊tomcat.cer文件,按照提示安裝證書,將證書填入到“受信任的根證書頒發機構”。

5、配置Tomcat服務器

a、打開tomcat配置文件,如:D:/Tomcat/conf/server.xml,修改如下,

1 <Connector port="8080" protocol="HTTP/1.1"
2                connectionTimeout="20000"
3                redirectPort="8443" />

修改參數為:

1 <Connector port="8080" protocol="HTTP/1.1"
2                connectionTimeout="20000"
3                redirectPort="443" />

 

1 <!--
2 <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
3               maxThreads="150" scheme="https" secure="true"
4               clientAuth="false" sslProtocol="TLS"/>
5  -->

去掉注釋且修改參數為:

1 <Connector port="443" protocol="HTTP/1.1" SSLEnabled="true"
2                maxThreads="150" scheme="https" secure="true"
3                clientAuth="false" sslProtocol="TLS" keystoreFile="D:/homes/tomcat.keystore" keystorePass="123123"/>

注釋:

keystoreFile、keystorePass 兩個參數,分別是證書文件的位置和<tomcat>的主密碼,在證書文件生成過程中做了設置
1 <!--
2    <Connector port="8009" enableLookups="false" protocol="AJP/1.3" redirectPort="8443" />
3 -->

修改參數

1 <Connector port="8009" enableLookups="false" protocol="AJP/1.3" redirectPort="443" />

b、打開D:/Tomcat/conf/web.xml,在該文件</welcome-file-list>后面加上這樣一段:

 1 <login-config> 
 2 <!-- Authorization setting for SSL --> 
 3 <auth-method>CLIENT-CERT</auth-method> 
 4 <realm-name>Client Cert Users-only Area</realm-name> 
 5 </login-config> 
 6 <security-constraint> 
 7 <!-- Authorization setting for SSL --> 
 8 <web-resource-collection > 
 9 <web-resource-name >SSL</web-resource-name> 
10 <url-pattern>/*</url-pattern> 
11 </web-resource-collection> 
12 <user-data-constraint> 
13 <transport-guarantee>CONFIDENTIAL</transport-guarantee> 
14 </user-data-constraint> 
15 </security-constraint>

結果: 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM