HTTPS協議在Tomcat中啟用的配置

本文將講解HTTPS協議在Tomcat中啟用是如何配置的。

概念簡介

Tomcat?服務器是一個免費的開放源代碼的Web 應用服務器,屬于輕量級應用服務器,在中小型系統和并發訪問用戶不是很多的場合下被普遍使用,是開發和調試 JSP 程序的首選。

HTTP?超文本傳輸協議(HTTP,HyperText Transfer Protocol)是互聯網上應用最為廣泛的一種網絡協議。所有的WWW文件都必須遵守這個標準。

HTTPS(全稱:Hyper Text Transfer Protocol over Secure Socket Layer),是以安全為目標的HTTP通道,簡單講是HTTP的安全版。

HTTPS和HTTP的區別

一、HTTP 是超文本傳輸協議,信息是明文傳輸,HTTPS 則是具有安全性的 SSL 加密傳輸協議。

二、HTTPS 協議需要到 CA 申請證書,一般免費證書很少,需要交費。

三、HTTP 和 HTTPS 使用的是完全不同的連接方式,用的端口也不一樣,前者是?80,后者是?443

四、HTTP 的連接很簡單,是無狀態的;HTTPS 協議是由 SSL+HTTP 協議構建的可進行加密傳輸、身份認證的網絡協議,比 HTTP 協議安全。

本地模擬測試開啟過程

HTTPS 如果生產環境應用在域名上是需要直接或間接的從 CA 申請證書,來取得瀏覽器的信任的。我們先在本地模擬測試一下這個過程,自己生成證書,后面介紹域名啟用 HTTPS。

① keytool工具生成證書

打開 JDK 自帶的 keytool 目錄。

這里寫圖片描述

按住 Shift 鍵,同時右鍵點擊空白處。

這里寫圖片描述

此時,進入cmd窗口。輸入下面命令。

keytool -genkeypair -alias "tomcat" -keyalg "RSA" -keystore "D:\tomcat.keystore" 
  • 1

接著會讓你填寫一些基本信息。

這里寫圖片描述

下面簡要介紹一下。

密鑰庫口令:123456(這個密碼非常重要)
名字與姓氏:192.168.0.110(以后訪問的域名或IP地址,非常重要,證書和域名或IP綁定) 組織單位名稱:anything(隨便填) 組織名稱:anything(隨便填) 城市:anything(隨便填) 省市自治區:anything(隨便填) 國家地區代碼:anything(隨便填)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

② 應用證書到Tomcat

打開 Tomcat 配置文件?conf\server.xml

取消注釋,并添加兩個屬性?keystoreFilekeystorePass

<Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true" maxThreads="150" scheme="https" secure="true" clientAuth="false" sslProtocol="TLS" keystoreFile="E:/tomcat.keystore" keystorePass="123456" />
  • 1
  • 2
  • 3

其中,keystoreFile是上一步生成的證書文件地址,keystorePass是上一步的密鑰庫口令。

③ 測試HTTPS

測試鏈接類似于這種?https://192.168.0.110:8443/your_project_name

觀察Tomcat輸出日志會發現異常。

嚴重: Failed to initialize end point associated with ProtocolHandler ["http-apr-8443"]  
java.lang.Exception: Connector attribute SSLCertificateFile must be defined when using SSL with APRat org.apache.tomcat.util.net.AprEndpoint.bind(AprEndpoint.java:484) at org.apache.tomcat.util.net.AbstractEndpoint.init(AbstractEndpoint.java:566) at org.apache.coyote.AbstractProtocol.init(AbstractProtocol.java:417) at org.apache.catalina.connector.Connector.initInternal(Connector.java:956) at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:102) at org.apache.catalina.core.StandardService.initInternal(StandardService.java:559) 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

解決方法是注釋conf\server.xml文件中下面一行。

<!--<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />-->
  • 1

重啟Tomcat ,這時可以看到瀏覽器已經可以打開 HTTPS 鏈接了。

真實域名開啟過程

使用自己生成的證書會遇到幾個問題。

一、瀏覽器會對 HTTPS 使用危險標識。

這里寫圖片描述

我們開啟 HTTPS 本意是為了更安全,增加用戶信心。但是瀏覽器使用危險標識會適得其反,嚇跑用戶。

二、瀏覽器默認不會加載非HTTPS域名下的javascript

這里寫圖片描述

我了個擦,這和早年的禁用javascript差不多了。已經影響網頁的正常運行了。

三、移動設備顯示頁面空白

手機瀏覽器打開頁面,也會像桌面瀏覽器一樣彈出是否加載不受信任的頁面,在微信中打開則會一片空白。


以上種種,導致自己生成的證書無法在生產環境使用。

解決以上問題,需要購買CA的證書。不過我在阿里云上看到有免費的證書申請。https://www.aliyun.com/product/cas

① 申請證書

購買過程就不詳細說了。照著阿里云的提示一步一步做就好了。

證書生成后,會得到PFX類型的證書。

② Tomcat 配置PFX證書

打開 Tomcat 配置文件?conf\server.xml

取消注釋,并添加三個屬性?keystoreFilekeystoreTypekeystorePass

<Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true" maxThreads="150" scheme="https" secure="true" clientAuth="false" sslProtocol="TLS" keystoreFile="/你的磁盤目錄/訂單號.pfx" keystoreType="PKCS12" keystorePass="訂單號" />
  • 1
  • 2
  • 3
  • 4
  • 5

其中,keystoreFile是PFX證書文件地址,keystorePass是阿里云的訂單號,keystoreType直接寫PKCS12 。

③ 測試真實域名

重新啟動Tomcat,訪問你自己的域名,則可以正常使用了。瀏覽器會有綠色的域名標識,移動設備也正常了。至于http域名下的javascript,還是需要更換為https才能正常加載。

對于要不要使用 https,需要根據實際情況具體考慮,https會比http慢一些,但是會更安全。

參考文獻

http://lixor.iteye.com/blog/1532655

?

個人之言,請抱著懷疑的態度參考!

轉載于:https://www.cnblogs.com/bozaiggg/p/7896153.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/370465.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/370465.shtml
英文地址,請注明出處:http://en.pswp.cn/news/370465.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

CSS3實現煙花特效 --web前端

煙花特效&#xff0c;比較簡單&#xff0c;直接貼代碼了……<!DOCTYPE html><html lang"en"><head> <meta charset"UTF-8"> <title>css3實現煙花特效</title> <style> * { margin: 0; padding: 0; } html{ widt…

虛擬機 java 開發_深入淺出 Java 虛擬機 · 通往高級 Java 開發的必經之路

第一章 JVM 內存模型Java 虛擬機(Java Virtual MachineJVM)的內存空間分為五個部分&#xff0c;分別是&#xff1a;程序計數器Java 虛擬機棧本地方法棧堆方法區。下面對這五個區域展開深入的介紹。1.1 程序計數器1.1.1 什么是程序計數器&#xff1f;程序計數器是一塊較小的內存…

java.lang.ClassNotFoundException:如何解決

本文適用于當前面臨java.lang.ClassNotFoundException挑戰的Java初學者。 它將為您提供此常見Java異常的概述&#xff0c;這是一個示例Java程序&#xff0c;可支持您的學習過程和解決策略。 如果您對與更高級的類加載器相關的問題感興趣&#xff0c;我建議您復習有關java.lang…

iOS10 App跳轉到系統設置

實現類似萬能鑰匙中點擊一個Wi-Fi跳轉到系統Wi-Fi設置界面的功能。 NSString * urlString "App-Prefs:rootWIFI";if ([[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:urlString]]) {if ([[UIDevice currentDevice].systemVersion doubleValue…

python生成器 圖片分類_python批量處理圖片圖片Python迭代器和生成器介紹

Python迭代器和生成器介紹迭代器迭代器是一個實現了迭代器協議的對象&#xff0c;Python中的迭代器協議就是有next方法的對象會前進到下一結果&#xff0c;而在一系列結果的末尾是&#xff0c;則會引發StopIteration。在for循環中&#xff0c;Python將自動調用工廠函數iter()獲…

Java-IO流之BufferedReader 和BufferedWriter的使用和原理

BufferedReader和BufferedWriter出現的目的是為了對FileReader以及FileWriter的讀寫操作進行增強&#xff0c;而怎么增強呢&#xff0c;原理類似于使用StringBuilder&#xff0c;是把數據先放入他們的一個char數組中&#xff0c;然后再操作char數組。 使用緩沖區的字符流是使用…

小程序實踐(三):九宮格實現及item跳轉

效果圖&#xff1a; 實現效果圖紅色線包含部分的九宮格效果&#xff0c;并附帶item點擊時間。 ------------------------------------------------------------------------------------------------------ 具體實現&#xff1a; 1、首先添加圖片資源文件 在項目根目錄新建一個…

用JavaFX編寫圖塊引擎

隨著JavaFX嵌入式版本的問世&#xff0c;我們的框架對于游戲開發變得越來越有趣&#xff0c;因為我們現在可以瞄準平板電腦和智能手機等小型消費類設備。 因此&#xff0c;我決定對JavaFX進行更多的游戲編寫實驗。 這次&#xff0c;我想使用Canvas對渲染進行更多控制&#xff0…

python命令行運行模式_[Python] 命令行模式閱讀博客園的博文

1 #-*- coding:UTF-8 -*-2 importrequests3 from lxml importetree4 importsys5 importio6 importos789 sys.stdout io.TextIOWrapper(sys.stdout.buffer, encodinggb18030)101112 classCnBlogs:13 """"14 Auth&#xff1a;reader15 發表地址&#xff1a;…

HTML5--應用網頁模板

因為剛開始寫博客,只想著把知識點記錄在這,也想給你們一些參考,在布局上有些沒有思考太多;回過頭來看,實在是不忍直視,對不住之前閱讀的100 ,既然昨天的事無法挽回,那就從現在開始從新整改吧!也希望大家看了,能對你們有所幫助 1.先給大家看看效果圖,好讓大家有點興趣 2.大家再來…

企業集成模式簡介

在此博客文章中&#xff0c;我們將介紹一些企業集成模式。 這些是旨在解決集成挑戰的已知設計模式。 閱讀此書后&#xff0c;您將可以設計集成解決方案。 EIP&#xff08;簡而言之&#xff09;是已知的設計模式&#xff0c;可為應用程序集成過程中遇到的問題/問題提供解決方案…

手把手教你Chrome瀏覽器安裝Postman(含下載云盤鏈接)【轉載】

轉載自&#xff1a;http://www.ljwit.com/archives/php/278.html 說明&#xff1a; Postman不多介紹&#xff0c;是一款功能強大的網頁調試與發送網頁HTTP請求的Chrome插件。本文主要介紹下安裝過程。 本文使用的是解壓文件直接進行安裝。是比較快速有效的安裝方式&#xff0c;…

C語言博客作業--數據類型

題目1&#xff1a;7-4 打印菱形圖案 1. 本題PTA提交列表 2. 設計思路 1.定義變量i,j,k,n;且聲明i為要打印的行數&#xff0c;j是控制輸出打印空格和星星&#xff0c;n是菱形為菱形的高 2.輸入n 3.i1&#xff0c;j1 4.先打印上半部分&#xff0c;第一行到n/21行&#xff0c;輸出…

信息隱藏將txt文件合并到jpg文件中_使用Kali Linux在圖像內隱藏機密消息—可在任何Linux發行版使用

歡迎回到“Esn技術社區”&#xff01;今天&#xff0c;我們將演示如何使用Steghide(一種可在Kali Linux上使用的流行隱寫工具)在圖像內隱藏消息。在計算機科學中&#xff0c;將信息隱藏在文件內(例如圖像&#xff0c;文檔&#xff0c;程序&#xff0c;有用數據&#xff0c;消息…

Spring 3.1,Cloud Foundry和本地開發

這篇文章將幫助您在Cloud Foundry上使用MongoDB構建Spring 3.1 Web應用程序。 除了推動Cloud Foundry之外&#xff0c;您還可以使用MongoDB實例在本地環境中進行開發。 目標 此博客發布的目標是在本地構建應用程序&#xff0c;然后發布到本地Cloud Foundry實例。 我們將利用C…

Spring MVC 簡述:從MVC框架普遍關注的問題說起

任何一個完備的MVC框架都需要解決Web開發過程中的一些共性的問題&#xff0c;比如請求的收集與分發、數據前后臺流轉與轉換&#xff0c;當前最流行的SpringMVC和Struts2也不例外。本文首先概述MVC模式的分層思想與MVC框架普遍關注的問題&#xff0c;并以此為契機結合SpringMVC的…

java方法調用機制_Java方法調用機制 - osc_bkdv2it5的個人空間 - OSCHINA - 中文開源技術交流社區...

最近在編程時&#xff0c;修改方法傳入對象的對象引用&#xff0c;并沒有將修改反映到調用方法中。奇怪為什么結果沒有變化&#xff0c;原因是遺忘了Java對象引用和內存分配機制。本文介紹3個點&#xff1a;① 該問題舉例說明② 簡要闡述Java內存區域③ 介紹JVM中方法調用的機制…

CSS染色圖標(圖片)

之前一直以為用background引入的圖標無法染色&#xff08;非字體圖標&#xff09;&#xff0c;現在才知道有黑科技可以用&#xff0c;就是利用drop-shadow。 代碼示例 <!DOCTYPE html> <html> <head lang"en"><meta charset"UTF-8"&…

eclipse安裝java web插件

1 查看eclipse版本 找到eclipse的安裝目錄&#xff0c;找到readme文件&#xff0c;打開其中的html文件&#xff0c;我的是4.6版本的,代號是oxygen 2 安裝 打開eclipse,點擊help-Install new software-單擊add&#xff0c;在彈出窗口中輸入網址&#xff1a; http://download.ecl…

python正則表達式指南_Python正則表達式指南

1. 正則表達式基礎1.1. 簡單介紹正則表達式并不是Python的一部分。正則表達式是用于處理字符串的強大工具&#xff0c;擁有自己獨特的語法以及一個獨立的處理引擎&#xff0c;效率上可能不如str自帶的方法&#xff0c;但功能十分強大。得益于這一點&#xff0c;在提供了正則表達…