色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

SpringBoot 改造成https訪問的實(shí)現(xiàn)

瀏覽:4日期:2023-04-19 11:19:31

SpringBoot https改造

1.生成密鑰證書

生成命令:keytool -genkey -alias tomcat -storetype PKCS12 -keyalg RSA -keysize 2048 -keystore keystore.p12 -validity 3650

(1)關(guān)鍵字解釋:

alias 密鑰別名

storetype 指定密鑰倉庫類型

keyalg 生證書的算法名稱,RSA是一種非對稱加密算法

keysize 證書大小

keystore 生成的證書文件的存儲路徑

validity 證書的有效期

(2)生成證書注意:

在輸入證書生成命令之后,會提示輸入:

密鑰庫口令:證書密碼,在后面的項(xiàng)目中配置證書時用到

姓氏:一般沒什么用,在瀏覽器中查看證書時會顯示,用于正式場合的證書還是需要填寫標(biāo)準(zhǔn)。

組織單位:證書使用單位信息,一般沒什么用,在瀏覽器中查看證書時會顯示,用于正式場合的證書還是需要填寫標(biāo)準(zhǔn)。

組織單位名稱:證書使用單位名稱,一般沒什么用,在瀏覽器中查看證書時會顯示,用于正式場合的證書還是需要填寫標(biāo)準(zhǔn)。

所在的城市或區(qū)域名稱:瀏覽器中查看證書信息時會顯示。

所在的省/市/自治區(qū)名稱:瀏覽器中查看證書信息時會顯示。

單位的雙字母國家/地區(qū)代碼:國家或地區(qū)編碼,瀏覽器中查看證書信息時會顯示。

2.將生成的密鑰證書拷貝到項(xiàng)目中的resource中(也可以不拷貝到項(xiàng)目中,后面配置路徑時配置密鑰證書的絕對路徑即可)。

SpringBoot 改造成https訪問的實(shí)現(xiàn)

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

SpringBoot 改造成https訪問的實(shí)現(xiàn)

server.ssl.key-store=classpath:keystore.p12 (密鑰文件路徑,也可以配置絕對路徑)

server.ssl.key-store-password=aqjcpt (密鑰生成時輸入的密鑰庫口令)

server.ssl.keyStoreType=PKCS12 (密鑰類型,與密鑰生成命令一致)

server.ssl.keyAlias=tomcat (密鑰別名,與密鑰生成命令一致)

4.啟動項(xiàng)目,直接訪問項(xiàng)目即可:

SpringBoot 改造成https訪問的實(shí)現(xiàn)

補(bǔ)充知識:SpringBoot配置HTTPS,并實(shí)現(xiàn)HTTP訪問自動轉(zhuǎn)HTTPS訪問

這里說一下為什么寫這篇文章,因?yàn)槲乙彩且粋€SpringBoot初學(xué)者,在配置https的時候遇到了一些坑,根據(jù)網(wǎng)上的配置方式,發(fā)現(xiàn)一些類已經(jīng)過時,這里僅以記錄一下我的配置過程,以供參考.

1.使用jdk自帶的 keytools 創(chuàng)建證書

打開cmd窗口,輸入如下命令

keytool -genkey -alias tomcat -keyalg RSA -keystore ./server.keystore

按照提示進(jìn)行操作

輸入密鑰庫口令:123456再次輸入新口令:123456您的名字與姓氏是什么?[Unknown]: kaibowang您的組織單位名稱是什么?[Unknown]: yuxuelian您的組織名稱是什么?[Unknown]: yuxuelian您所在的城市或區(qū)域名稱是什么?[Unknown]: chengdu您所在的省/市/自治區(qū)名稱是什么?[Unknown]: chengdushi該單位的雙字母國家/地區(qū)代碼是什么?[Unknown]: chinaCN=kaibowang, OU=yuxuelian, O=yuxuelian, L=chengdu, ST=chengdushi, C=china是否正確?[否]: y輸入 <tomcat> 的密鑰口令(如果和密鑰庫口令相同, 按回車):再次輸入新口令:Warning:JKS 密鑰庫使用專用格式。建議使用 'keytool -importkeystore -srckeystore C:UsersAdministrator.keystore -destkeystore C:UsersAdministrator.keystore -deststoretype pkcs12' 遷移到行業(yè)標(biāo)準(zhǔn)格式 PKCS12。

創(chuàng)建完成后,可在用戶根目錄查看生成的keystore文件

2.新建springboot項(xiàng)目,將上一步生成的keystone文件復(fù)制到項(xiàng)目的根目錄,在application.properties添加如下配置

server.port=443server.ssl.key-store=server.keystoreserver.ssl.key-alias=tomcatserver.ssl.enabled=trueserver.ssl.key-store-password=123456server.ssl.key-store-type=JKS

這里將服務(wù)器端口號設(shè)置成443端口,即https的默認(rèn)訪問端口,那么在進(jìn)行https訪問的時候可以不帶端口號直接訪問,如果端口被占用使用

netstat -ano

查看哪個進(jìn)程號占用了端口,使用

tasklist|findstr (查看到的進(jìn)程號)# simpleC:UsersAdministrator>tasklist|findstr 3664vmware-hostd.exe 3664 Services 0 5,040 K

打開任務(wù)管理器,殺死占用進(jìn)程,或打開對應(yīng)的應(yīng)用程序的設(shè)置,關(guān)閉監(jiān)聽

至此 https配置完畢 訪問 https://localhost 查看是否配置成功

3.http訪問自動轉(zhuǎn)https訪問

向spring容器中注入兩個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 這個類,網(wǎng)上清一色的都是使用 EmbeddedServletContainerFactory 這個類.

在新版本的SpringBoot中,我發(fā)現(xiàn)已近找不到這個類了,幾經(jīng)周轉(zhuǎn),翻閱源碼,才找到這個類,這也是我為什么寫這篇文章的初衷.

其次在這里設(shè)置http的監(jiān)聽端口為80端口,http默認(rèn)端口,這樣在訪問的時候也可以不用帶上端口號.

完成以上配置后,我們訪問 http://localhost 即可自動跳轉(zhuǎn)為 https://localhost

以上這篇SpringBoot 改造成https訪問的實(shí)現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 亚洲久久成人 | 精品视频在线观看一区二区三区 | 日韩毛片免费线上观看 | 日本精品久久久久久久久免费 | 欧美做爰免费大片在线观看 | 久久精品免费一区二区三区 | 久草网址| 国产在线成人精品 | 一级毛片在播放免费 | 中文字幕精品一区二区精品 | 国产盗摄一区二区 | 久久91精品国产一区二区 | 国产高清在线免费视频 | japanesetubesexfree | 91寡妇天天综合久久影院 | 日韩黄在线观看免费视频 | 五月久久亚洲七七综合中文网 | 亚洲精品人成网线在线 | 一级黄片一级毛片 | 久久欧美成人精品丝袜 | 久久综合给会久久狠狠狠 | 亚洲日韩精品欧美一区二区 | 欧美成人性做爰 | 亚洲天堂爱爱 | 国产成人午夜精品免费视频 | 欧美日韩国产在线观看一区二区三区 | 国产欧美一区二区 | 久久久毛片 | 亚洲天堂影院在线观看 | fc2成年手机免费共享视频 | 狠狠色丁香婷婷久久综合考虑 | 久青草免费在线视频 | 国产激情一区二区三区 | 午夜影院免费入口 | 成人毛片在线视频 | 亚洲欧美日韩综合一区久久 | 国产系列 视频二区 | 精品99在线观看 | 国产欧美一区二区三区观看 | 美国一级视频 | 欧美一级毛级毛片 |