SpringBoot 改造成https訪問(wèn)的實(shí)現(xiàn)
SpringBoot https改造
1.生成密鑰證書(shū)
生成命令:keytool -genkey -alias tomcat -storetype PKCS12 -keyalg RSA -keysize 2048 -keystore keystore.p12 -validity 3650
(1)關(guān)鍵字解釋:
alias 密鑰別名
storetype 指定密鑰倉(cāng)庫(kù)類型
keyalg 生證書(shū)的算法名稱,RSA是一種非對(duì)稱加密算法
keysize 證書(shū)大小
keystore 生成的證書(shū)文件的存儲(chǔ)路徑
validity 證書(shū)的有效期
(2)生成證書(shū)注意:
在輸入證書(shū)生成命令之后,會(huì)提示輸入:
密鑰庫(kù)口令:證書(shū)密碼,在后面的項(xiàng)目中配置證書(shū)時(shí)用到
姓氏:一般沒(méi)什么用,在瀏覽器中查看證書(shū)時(shí)會(huì)顯示,用于正式場(chǎng)合的證書(shū)還是需要填寫(xiě)標(biāo)準(zhǔn)。
組織單位:證書(shū)使用單位信息,一般沒(méi)什么用,在瀏覽器中查看證書(shū)時(shí)會(huì)顯示,用于正式場(chǎng)合的證書(shū)還是需要填寫(xiě)標(biāo)準(zhǔn)。
組織單位名稱:證書(shū)使用單位名稱,一般沒(méi)什么用,在瀏覽器中查看證書(shū)時(shí)會(huì)顯示,用于正式場(chǎng)合的證書(shū)還是需要填寫(xiě)標(biāo)準(zhǔn)。
所在的城市或區(qū)域名稱:瀏覽器中查看證書(shū)信息時(shí)會(huì)顯示。
所在的省/市/自治區(qū)名稱:瀏覽器中查看證書(shū)信息時(shí)會(huì)顯示。
單位的雙字母國(guó)家/地區(qū)代碼:國(guó)家或地區(qū)編碼,瀏覽器中查看證書(shū)信息時(shí)會(huì)顯示。
2.將生成的密鑰證書(shū)拷貝到項(xiàng)目中的resource中(也可以不拷貝到項(xiàng)目中,后面配置路徑時(shí)配置密鑰證書(shū)的絕對(duì)路徑即可)。

3.修改項(xiàng)目配置文件application.properties,增加如下配置項(xiàng):

server.ssl.key-store=classpath:keystore.p12 (密鑰文件路徑,也可以配置絕對(duì)路徑)
server.ssl.key-store-password=aqjcpt (密鑰生成時(shí)輸入的密鑰庫(kù)口令)
server.ssl.keyStoreType=PKCS12 (密鑰類型,與密鑰生成命令一致)
server.ssl.keyAlias=tomcat (密鑰別名,與密鑰生成命令一致)
4.啟動(dòng)項(xiàng)目,直接訪問(wèn)項(xiàng)目即可:

補(bǔ)充知識(shí):SpringBoot配置HTTPS,并實(shí)現(xiàn)HTTP訪問(wèn)自動(dòng)轉(zhuǎn)HTTPS訪問(wèn)
這里說(shuō)一下為什么寫(xiě)這篇文章,因?yàn)槲乙彩且粋€(gè)SpringBoot初學(xué)者,在配置https的時(shí)候遇到了一些坑,根據(jù)網(wǎng)上的配置方式,發(fā)現(xiàn)一些類已經(jīng)過(guò)時(shí),這里僅以記錄一下我的配置過(guò)程,以供參考.
1.使用jdk自帶的 keytools 創(chuàng)建證書(shū)
打開(kāi)cmd窗口,輸入如下命令
keytool -genkey -alias tomcat -keyalg RSA -keystore ./server.keystore
按照提示進(jìn)行操作
輸入密鑰庫(kù)口令:123456
再次輸入新口令:123456
您的名字與姓氏是什么?
[Unknown]: kaibowang
您的組織單位名稱是什么?
[Unknown]: yuxuelian
您的組織名稱是什么?
[Unknown]: yuxuelian
您所在的城市或區(qū)域名稱是什么?
[Unknown]: chengdu
您所在的省/市/自治區(qū)名稱是什么?
[Unknown]: chengdushi
該單位的雙字母國(guó)家/地區(qū)代碼是什么?
[Unknown]: china
CN=kaibowang, OU=yuxuelian, O=yuxuelian, L=chengdu, ST=chengdushi, C=china是否正確?
[否]: y
輸入 <tomcat> 的密鑰口令
(如果和密鑰庫(kù)口令相同, 按回車):
再次輸入新口令:
Warning:
JKS 密鑰庫(kù)使用專用格式。建議使用 "keytool -importkeystore -srckeystore C:\Users\Administrator\.keystore -destkeystore C:\Users\Administrator\.keystore -deststoretype pkcs12" 遷移到行業(yè)標(biāo)準(zhǔn)格式 PKCS12。
創(chuàng)建完成后,可在用戶根目錄查看生成的keystore文件
2.新建springboot項(xiàng)目,將上一步生成的keystone文件復(fù)制到項(xiàng)目的根目錄,在application.properties添加如下配置
server.port=443
server.ssl.key-store=server.keystore
server.ssl.key-alias=tomcat
server.ssl.enabled=true
server.ssl.key-store-password=123456
server.ssl.key-store-type=JKS
這里將服務(wù)器端口號(hào)設(shè)置成443端口,即https的默認(rèn)訪問(wèn)端口,那么在進(jìn)行https訪問(wèn)的時(shí)候可以不帶端口號(hào)直接訪問(wèn),如果端口被占用使用
netstat -ano
查看哪個(gè)進(jìn)程號(hào)占用了端口,使用
tasklist|findstr (查看到的進(jìn)程號(hào))
# simple
C:\Users\Administrator>tasklist|findstr 3664
vmware-hostd.exe 3664 Services 0 5,040 K
打開(kāi)任務(wù)管理器,殺死占用進(jìn)程,或打開(kāi)對(duì)應(yīng)的應(yīng)用程序的設(shè)置,關(guān)閉監(jiān)聽(tīng)
至此 https配置完畢 訪問(wèn) https://localhost 查看是否配置成功
3.http訪問(wèn)自動(dòng)轉(zhuǎn)https訪問(wèn)
向spring容器中注入兩個(gè)Bean,代碼如下
@Bean
public Connector connector(){
Connector connector=new Connector("org.apache.coyote.http11.Http11NioProtocol");
connector.setScheme("http");
connector.setPort(80);
connector.setSecure(false);
connector.setRedirectPort(443);
return connector;
}
@Bean
public TomcatServletWebServerFactory tomcatServletWebServerFactory(Connector connector){
TomcatServletWebServerFactory tomcat=new TomcatServletWebServerFactory(){
@Override
protected void postProcessContext(Context context) {
SecurityConstraint securityConstraint=new SecurityConstraint();
securityConstraint.setUserConstraint("CONFIDENTIAL");
SecurityCollection collection=new SecurityCollection();
collection.addPattern("/*");
securityConstraint.addCollection(collection);
context.addConstraint(securityConstraint);
}
};
tomcat.addAdditionalTomcatConnectors(connector);
return tomcat;
}
首先 這里需要使用 TomcatServletWebServerFactory 這個(gè)類,網(wǎng)上清一色的都是使用 EmbeddedServletContainerFactory 這個(gè)類.
在新版本的SpringBoot中,我發(fā)現(xiàn)已近找不到這個(gè)類了,幾經(jīng)周轉(zhuǎn),翻閱源碼,才找到這個(gè)類,這也是我為什么寫(xiě)這篇文章的初衷.
其次在這里設(shè)置http的監(jiān)聽(tīng)端口為80端口,http默認(rèn)端口,這樣在訪問(wèn)的時(shí)候也可以不用帶上端口號(hào).
完成以上配置后,我們?cè)L問(wèn) http://localhost 即可自動(dòng)跳轉(zhuǎn)為 https://localhost
以上這篇SpringBoot 改造成https訪問(wèn)的實(shí)現(xiàn)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- SSL證書(shū)部署+SpringBoot實(shí)現(xiàn)HTTPS安全訪問(wèn)的操作方法
- SpringBoot配置Https訪問(wèn)的詳細(xì)步驟
- SpringBoot配置SSL同時(shí)支持http和https訪問(wèn)實(shí)現(xiàn)
- SpringBoot2.x配置HTTPS訪問(wèn)的過(guò)程
- springboot+nginx+https+linux實(shí)現(xiàn)負(fù)載均衡加域名訪問(wèn)簡(jiǎn)單測(cè)試
- springboot配置https訪問(wèn)的方法
- SpringBoot應(yīng)用的接口訪問(wèn)從HTTP改為HTTPS
相關(guān)文章
關(guān)于單例模式懶漢式和餓漢式的區(qū)別及說(shuō)明
這篇文章主要介紹了關(guān)于單例模式懶漢式和餓漢式的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
Java多線程之Semaphore實(shí)現(xiàn)信號(hào)燈
這篇文章主要給大家分享的是Java多線程之Semaphore實(shí)現(xiàn)信號(hào)燈的練習(xí),emaphore是計(jì)數(shù)信號(hào)量。Semaphore管理一系列許可證。每個(gè)acquire方法阻塞,直到有一個(gè)許可證可以獲得然后拿走一個(gè)許可證;下面一起進(jìn)入文章學(xué)習(xí)Semaphore的具體內(nèi)容2021-10-10
Spring中的SpringApplicationRunListener詳細(xì)解析
這篇文章主要介紹了Spring中的SpringApplicationRunListener詳細(xì)解析,SpringApplicationRunListener是一個(gè)監(jiān)聽(tīng)SpringApplication中run方法的接口,在項(xiàng)目啟動(dòng)過(guò)程的各個(gè)階段進(jìn)行事件的發(fā)布,需要的朋友可以參考下2023-11-11
Java隨機(jī)生成手機(jī)短信驗(yàn)證碼的方法
這篇文章主要介紹了Java隨機(jī)生成手機(jī)短信驗(yàn)證碼的方法,涉及Java數(shù)學(xué)運(yùn)算計(jì)算隨機(jī)數(shù)及字符串操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11

