轉:java應用 tomcat中實現https安全連線的方法
SSL, 或者Secure Socket Layer,是一種允許web瀏覽器和web伺服器透過一個安全的連線進行交流的技術。這意味著將被髮送的資料在一端被翻譯成密碼,傳送出去,然後在另一端解開密碼,再進行處理。這是一個雙向的過程,也就是瀏覽器和伺服器都需要在傳送資料之前對它們進行加密。
[@more@]SSL協定的另一個重要方面是認證(Authentication)。這就是說,在你開始試圖透過一個安全連線與一個web伺服器交流的時候,這個伺服器會要求你的瀏覽器出示一組證件,透過“鑑定”的方式來證明這就是你所宣告的網站。
在某些情況下,伺服器還會要求你的web瀏覽器的認證照,證明你就是你所說的那個人。這就是所知的“客戶認證”,儘管實際情況中,更多地用在商務-對-商務(B2B)交易,而不是對個人使用者。
但大多數有SSL功能的web伺服器不要求客戶認證(Client Authentication)。
證照
為了能實施SSL,一個web伺服器對每個接受安全連線的外部介面(IP 地址)必須要有相應的證照(Certificate)。關於這個設計的理論是一個伺服器必須提供某種合理的保證以證明這個伺服器的主人就是你所認為的那個人。這個證照要陳述與這個網站相關聯的公司,以及這個網站的所有者或系統管理員的一些基本聯絡資訊。
這個證照由所有人以密碼方式簽字,其他人非常難偽造。對於進行電子商務(e-commerce)的網站,或其他身份認證至關重要的任何商業交易,認證照要向大家所熟知的認證權威(Certificate Authority (CA))如VeriSign或Thawte來購買。這樣的證照可用電子技術證明屬實。實際上,認證權威單位會擔保它發出的認證照的真實性,如果你信任發出認證照的認證權威單位的話,你就可以相信這個認證照是有效的。
在許多情況下,認證並不是真正使人擔憂的事。系統管理員或許只想要保證被伺服器傳送和接收的資料是秘密的,不會被連線線上的偷竊者盜竊到。慶幸的是,Java提供相對簡單的被稱為keytool的命令列工具,可以簡單地產生“自己簽名”的證照。自己簽名的證照只是使用者產生的證照,沒有正式在大家所熟知的認證權威那裡註冊過,因此不能確保它的真實性。但卻能保證資料傳輸的安全性。
認證也許很重要,也許不重要,完全決定於網站的需要。
用Tomcat來配置SSL主要有下面這麼兩大步驟:
一、生成證照
1、 在命令列下執行:
%Java_home%binkeytool -genkey -alias tomcat -keyalg RSA
在此命令中,keytool是JDK自帶的產生證照的工具。把RSA運演算法則作為主要安全運演算法則,這保證了與其它伺服器和元件的相容性。
這個命令會在使用者的home directory產生一個叫做" .keystore " 的新檔案。在執行後,你首先被要求出示keystore密碼。Tomcat使用的預設密碼是" changeit "(全都是小寫字母),如果你願意,你可以指定你自己的密碼。你還需要在server.xml配置檔案裡指定自己的密碼,這在以後會有描述。
2、 你會被要求出示關於這個認證照的一般性資訊,如公司,聯絡人名稱,等等。這些資訊會顯示給那些試圖訪問你程式裡安全網頁的使用者,以確保這裡提供的資訊與他們期望的相對應。
3、 你會被要求出示金鑰(key)密碼,也就是這個認證照所特有的密碼(與其它的儲存在同一個keystore檔案裡的認證照不同)。你必須在這裡使用與keystore密碼相同的密碼。(目前,keytool會提示你按ENTER鍵會自動幫你做這些)。
如果一切順利,你現在就擁有了一個可以被你的伺服器使用的有認證照的keystore檔案。
二、配置tomcat
第二個大步驟是把secure socket配置在$CATALINA_HOME/conf/server.xml檔案裡。$CATALINA_HOME代表安裝Tomcat的目錄。一個例子是SSL聯結器的元素被包括在和Tomcat一起安裝的預設server.xml檔案裡。它看起來象是這樣:
$CATALINA_HOME/conf/server.xml
< -- Define a SSL Coyote HTTP/1.1 Connector on port 8443 -->
< !--
< Connector
port="8443" minProcessors="5" maxProcessors="75"
enableLookups="true" disableUploadTimeout="true"
acceptCount="100" debug="0" scheme="https" secure="true";
clientAuth="false" sslProtocol="TLS"/>
-->
Connector元素本身,其預設形式是被註釋掉的(commented out),所以需要把它周圍的註釋標誌刪除掉。然後,可以根據需要客戶化(自己設定)特定的屬性。一般需要增加一下keystoreFile和keystorePass兩個屬性,指定你存放證照的路徑(如:keystoreFile="C:/.keystore")和剛才設定的密碼(如:keystorePass="123456")。關於其它各種選項的詳細資訊,可查閱Server Configuration Reference。
在完成這些配置更改後,必須象重新啟動Tomcat,然後你就可以透過SSL訪問Tomcat支援的任何web應用程式。只不過指令需要像下面這樣:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/220284/viewspace-1023490/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【Java】Spring和Tomcat自帶的連線池實現資料庫操作JavaSpringTomcat資料庫
- 理解https中的安全及其實現原理HTTP
- linux tomcat 開通443 (用https安全訪問)LinuxTomcatHTTP
- mysql的jdbc連線java實現MySqlJDBCJava
- TOMCAT和JAVA應用TomcatJava
- tomcat拒絕連線解決方法Tomcat
- Netty 實現SSL安全連線(wss://)Netty
- java實現連結串列反轉Java
- Tomcat中的session實現TomcatSession
- MVC模式在Java Web應用程式中的實現MVC模式JavaWeb
- Java中實現執行緒安全HashSet的幾種方法 | baeldungJava執行緒
- Tomcat 的 JDBC 連線池TomcatJDBC
- 【轉】Docker部署Tomcat及Web應用DockerTomcatWeb
- Java中實現1,000,000個併發連線Java
- 在Java中利用動態代理實現資料庫連線與事務的自動管理【轉】Java資料庫
- 如何在 Kubernetes 中實現應用的無損上線和下線
- Apache+tomcat實現應用伺服器叢集ApacheTomcat伺服器
- 用 HTTPS 安全嗎?HTTPS 的原理是啥?HTTP
- 線性代數在前端中的應用(二):實現滑鼠拖拽旋轉元素、Canvas圖形前端Canvas
- 如何用 Java 實現 Web 應用中的定時任務?JavaWeb
- Java程式中的代理作用和應用場景及實現Java
- 用連結串列的方式實現大數相減-Java實現Java
- django中的資料庫連線池實現Django資料庫
- Java應用伺服器之tomcat部署Java伺服器Tomcat
- Eclipse/tomcat 如何實現應用熱部署和熱啟動EclipseTomcat熱部署
- 使用 Java 客戶端透過 HTTPS 連線到 EasysearchJava客戶端HTTP
- 用Java實現samza轉換成flinkJava
- NGINX使用rewrite實現http 跳轉 httpsNginxHTTP
- XenServer中VMware的Console的連線方法Server
- Java中的Unsafe在安全領域的一些應用總結和復現Java
- Java技術之掌握資料庫連線工具DBUtils的應用Java資料庫
- 無線應用安全剖析
- KIDataGrip連線Mysql並建立資料庫的方法實現ztpMySql資料庫
- React/Vue 實現的前端應用, java/Go/Python 實現的後端應用,前後端分離的應用部署的最佳實踐ReactVue前端JavaGoPython後端
- 真正“搞”懂HTTPS協議16之安全的實現HTTP協議
- Nginx實現301跳轉至https的根域名展示NginxHTTP
- Java實現管線拓撲關係連通性分析Java
- PHP中的資料庫連線方法PHP資料庫
- Swoole MySQL 連線池的實現MySql