Spring Boot之內(nèi)嵌tomcat版本升級(jí)操作示例
Spring Boot之如何升級(jí)內(nèi)嵌tomcat版本
1. 背景
根據(jù)信息安全運(yùn)營(yíng)團(tuán)隊(duì)發(fā)布的Tomcat-AJP協(xié)議漏洞風(fēng)險(xiǎn)預(yù)警,Tomcat的AJP協(xié)議存在高危漏洞(默認(rèn)8009端口)由于存在實(shí)現(xiàn)缺陷導(dǎo)致相關(guān)參數(shù)可控,攻擊者利用該漏洞可通過(guò)構(gòu)造特定參數(shù),讀取服務(wù)器webapp 下的任意文件。若服務(wù)器端同時(shí)存在文件上傳功能,攻擊者可進(jìn)一步實(shí)現(xiàn)遠(yuǎn)程代碼的執(zhí)行。漏洞CVE編號(hào):CVE-2020-1938,此漏洞風(fēng)險(xiǎn)等級(jí)為高危。附件中為全行開(kāi)發(fā)、生產(chǎn)涉及的系統(tǒng),請(qǐng)大家盡快確認(rèn)是否使用了AJP協(xié)議并按照臨時(shí)方案進(jìn)行修復(fù)。
修復(fù)方案如下:
1、未使用AJP協(xié)議方案:直接關(guān)閉AJP協(xié)議
(1)編輯 <CATALINA_BASE>/conf/server.xml,找到如下行(<CATALINA_BASE> 為 Tomcat 的工作目錄):
<Connector port=“8009”protocol=“AJP/1.3” redirectPort=“8443” />
(2)將此行注釋掉(也可刪掉該行):
<!—<Connectorport=“8009” protocol=“AJP/1.3”redirectPort=“8443” />—>
(3)保存后需重新啟動(dòng),規(guī)則方可生效。
(4)重啟后執(zhí)行netstat -an|grep 8009 檢查8009端口已經(jīng)不在監(jiān)聽(tīng)狀態(tài)
2、使用AJP協(xié)議:建議將Tomcat立即升級(jí)到9.0.31、8.5.51或7.0.100版本進(jìn)行修復(fù)
雖然我們的產(chǎn)品使用內(nèi)嵌tomcat,只是使用其中的http協(xié)議,未用到AJP協(xié)議,且已將AJP協(xié)議關(guān)閉。但是鑒于客戶(hù)的安全意識(shí)很高,對(duì)此不認(rèn)同,強(qiáng)烈要求升級(jí)tomcat版本。于是開(kāi)始踩升級(jí)內(nèi)嵌tomcat的坑啦。
2. 過(guò)程
2.1 升級(jí)單模塊項(xiàng)目的tomcat版本
寫(xiě)了個(gè)demo測(cè)試內(nèi)嵌tomcat版本,很容易就升級(jí)了。在pom文件里寫(xiě)上tomcat想升級(jí)的版本,打包出來(lái),依賴(lài)的就是tomcat對(duì)應(yīng)的版本了。
<properties>
<tomcat.version>8.5.51</tomcat.version>
</properties>
但是這種升級(jí)需要pom里依賴(lài)父項(xiàng)目為org.springframework.boot,也就類(lèi)似于面向?qū)ο罄锏睦^承父類(lèi),并重寫(xiě)父類(lèi)對(duì)應(yīng)的方法,這個(gè)意思你懂的吧?也就是說(shuō)pom里有如下類(lèi)似標(biāo)注,否則直接寫(xiě)tomcat版本升級(jí)是不升效的。
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.8.RELEASE</version> </parent>
2.2 升級(jí)包含多個(gè)模塊的項(xiàng)目
升級(jí)多模塊的項(xiàng)目的tomcat版本,子模塊依賴(lài)tomcat,但是子模塊的父項(xiàng)目不可能是org.springframework.boot,而是項(xiàng)目對(duì)應(yīng)的父模塊,此時(shí)第一種方法就不見(jiàn)效了。那我們粗暴的,先將tomcat依賴(lài)剔除,再引入對(duì)應(yīng)版本的tomcat版本不就行了嘛。因?yàn)閠omcat相關(guān)的依賴(lài)再spring-boot-starter-web依賴(lài)模塊下面,所以先將它內(nèi)部包含的tomcat依賴(lài)剔除,再引入對(duì)應(yīng)的tomcat版本,具體如下:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
<exclusion>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-core</artifactId>
</exclusion>
<exclusion>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-el</artifactId>
</exclusion>
<exclusion>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-websocket</artifactId>
</exclusion>
<exclusion>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-annotations-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-core</artifactId>
<version>${tomcat.version}</version>
<exclusions>
<exclusion>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-annotations-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-annotations-api</artifactId>
<version>${tomcat.version}</version>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-el</artifactId>
<version>${tomcat.version}</version>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-websocket</artifactId>
<version>${tomcat.version}</version>
<exclusions>
<exclusion>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-core</artifactId>
</exclusion>
</exclusions>
</dependency>
3. 項(xiàng)目有打包子模塊如何升級(jí)
如果有自己打包子模塊,上述就會(huì)失效,具體原因還不清楚,但是也很好解決:將如上2步驟的依賴(lài)復(fù)制黏貼到打包子模塊的pom文件里,這樣就搞定。
尾聲
現(xiàn)在總結(jié)起來(lái)還是比較簡(jiǎn)單,但是前一段時(shí)間踩坑也是很腦殼疼的。一直升級(jí)不生效,只能各種嘗試,總算趕在項(xiàng)目發(fā)布前解決了,cheers !
以上就是Spring Boot之內(nèi)嵌tomcat版本升級(jí)操作示例的詳細(xì)內(nèi)容,更多關(guān)于Spring Boot內(nèi)嵌tomcat版本升級(jí)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java實(shí)現(xiàn)簡(jiǎn)單猜數(shù)字游戲
這篇文章主要介紹了java實(shí)現(xiàn)簡(jiǎn)單猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
使用Spring Batch實(shí)現(xiàn)批處理任務(wù)的詳細(xì)教程
在企業(yè)級(jí)應(yīng)用中,批處理任務(wù)是不可或缺的一部分,它們通常用于處理大量數(shù)據(jù),如數(shù)據(jù)遷移、數(shù)據(jù)清洗、生成報(bào)告等,Spring Batch是Spring框架的一部分,本文將介紹如何使用Spring Batch與SpringBoot結(jié)合,構(gòu)建和管理批處理任務(wù),需要的朋友可以參考下2024-06-06
java實(shí)現(xiàn)潛艇大戰(zhàn)游戲源碼
潛艇大戰(zhàn)游戲相信大家都玩過(guò),是一款非常有趣的小游戲,那么基于代碼是如何實(shí)現(xiàn)的呢?今天小編給大家?guī)?lái)一篇教程幫助大家學(xué)習(xí)java實(shí)現(xiàn)潛艇大戰(zhàn)游戲,感謝的朋友一起看看吧2021-06-06
springboot+vue實(shí)現(xiàn)oss文件存儲(chǔ)的示例代碼
對(duì)象存儲(chǔ)服務(wù)是一種海量、安全、低成本、高可靠的云存儲(chǔ)服務(wù),本文主要介紹了springboot+vue實(shí)現(xiàn)oss文件存儲(chǔ)的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02
springmvc 中dao層和service層的區(qū)別說(shuō)明
這篇文章主要介紹了springmvc 中dao層和service層的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
Spring根據(jù)URL參數(shù)進(jìn)行路由的方法詳解
這篇文章主要給大家介紹了關(guān)于Spring根據(jù)URL參數(shù)進(jìn)行路由的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起來(lái)看看吧。2017-12-12
Springboot注入成員變量HttpServletRequest的原理分析
這篇文章主要介紹了Springboot注入成員變量HttpServletRequest的原理分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05

