SpringBoot的HTTPS配置實現(xiàn)
HTTPS 配置
由于HTTPS具有良好的安全性,在開發(fā)中得到了越來越廣泛的應(yīng)用,像微信公眾號、小程序等的開發(fā)都要使用HTTPS來完成。對于個人開發(fā)者而言,一個HTTPS 證書的價格還是有點貴,國內(nèi)有一些云服務(wù)器廠商提供免費的HTTPS證書,一個賬號可以申請數(shù)個。不過在jdk中提供了一個Java數(shù)字證書管理工具keytool,在\jdkbin目錄下,通過這個工具可以自己生成一個數(shù)字證書,生成命令如下:
keytool -genkey -alias tomcathttps -keyalg RSA -keysize 2048 -keystore sang.p12 -validity 365
- genkey表示要創(chuàng)建一個新的密鑰。
- alias表示keystore的別名。
- keyalg表示使用的加密算法是RSA,一種非對稱加密算法。
- keysize表示密鑰的長度。
- keystore表示生成的密鑰存放位置。
- validity表示密鑰的有效時間,單位為天。
在cmd窗口中直接執(zhí)行如上命令,在執(zhí)行的過程中需要輸入密鑰口令等信息,根據(jù)提示輸入即可。命令執(zhí)行完成后,會在當(dāng)前用戶目錄下生成一個名為 sang.p12的文件,將這個文件復(fù)制到項目的根目錄下,然后在application.properties中做如下配置:
# key-store表示密鑰文件名。 server.ssl.key-store=sang.p12 # key-alias表示密鑰別名。 server.ssl.key-alias=tomcathttps #key-store-password 就是在cmd命令執(zhí)行過程中輸入的密碼。 server.ssl.key-store-password=123456
配置成功后,啟動項目,在瀏覽器中輸入“https:/localhost:8080”來查看結(jié)果。注意,證書是自己生成的,不被瀏覽器認(rèn)可,此時添加信任或者繼續(xù)前進即可,如圖所示。
成功運行的結(jié)果如圖
此時,如果以 HTTP 的方式訪問接口,就會訪問失敗,如圖
這是因為 Spring Boot 不支持同時在配置中啟動 HTTP HTTPS 。這個時候可以配置請求重定向,將 HTTP 請求重定向為 HTTPS 請求。配置方式如下
@Configuration public class TomcatConfig { @Bean TomcatServletWebServerFactory tomcatServletWebServerFactory() { TomcatServletWebServerFactory factory = new TomcatServletWebServerFactory() { @Override protected void postProcessContext(Context context) { SecurityConstraint constraint = new SecurityConstraint(); constraint.setUserConstraint("CONFIDENTIAL"); SecurityCollection collection = new SecurityCollection(); collection.addPattern("/*"); constraint.addCollection(collection); context.addConstraint(constraint); } }; factory.addAdditionalTomcatConnectors(createTomcatConnector()); return factory; } private Connector createTomcatConnector() { Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol"); connector.setScheme("http"); connector.setPort(8080); connector.setSecure(false); connector.setRedirectPort(8081); return connector; } }
這里首先配置一個TomcatServletWebServerFactory,然后添加一個Tomcat 中的Connector(監(jiān)聽8080端口),并將請求轉(zhuǎn)發(fā)到8081上去。
配置完成后,在瀏覽器中輸入“http://localhost:8080/”,就會自動重定向到https://localhost:8081/ 上。
到此這篇關(guān)于SpringBoot的HTTPS配置實現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot HTTPS配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- springboot如何配置ssl支持https
- SpringBoot配置HTTPS及開發(fā)調(diào)試的操作方法
- springboot實現(xiàn)的https單向認(rèn)證和雙向認(rèn)證(java生成證書)
- SpringBoot配置Https訪問的詳細(xì)步驟
- SpringBoot配置Https入門實踐
- springboot項目開啟https協(xié)議的項目實現(xiàn)
- springboot配置http跳轉(zhuǎn)https的過程
- springboot如何將http轉(zhuǎn)https
- springboot支持https請求的實現(xiàn)
- SpringBoot中支持Https協(xié)議的實現(xiàn)
- SpringBoot整合HTTPS的項目實踐
相關(guān)文章
java application maven項目打自定義zip包實例(推薦)
下面小編就為大家?guī)硪黄猨ava application maven項目打自定義zip包實例(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05mybatis-plus mapper中foreach循環(huán)操作代碼詳解(新增或修改)
這篇文章主要介紹了mybatis-plus mapper中foreach循環(huán)操作代碼詳解(新增或修改),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11java?使用BeanFactory實現(xiàn)service與dao層解耦合詳解
這篇文章主要介紹了java?使用BeanFactory實現(xiàn)service與dao層解耦合詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12淺談java并發(fā)之計數(shù)器CountDownLatch
CountDownLatch是通過一個計數(shù)器來實現(xiàn)的,當(dāng)我們在new 一個CountDownLatch對象的時候需要帶入該計數(shù)器值,該值就表示了線程的數(shù)量。下面我們來深入了解一下吧2019-06-06Java多線程執(zhí)行處理業(yè)務(wù)時間太久解決方法代碼示例
這篇文章主要介紹了Java多線程執(zhí)行處理業(yè)務(wù)時間太久解決方法代碼示例的相關(guān)資料,具有一定借鑒價值,需要的朋友可以參考下。2017-12-12