spring boot 修復 Spring Framework URL解析不當漏洞(CVE-2024-22243)

漏洞描述

當應用程序使用UriComponentsBuilder來解析外部提供的URL(如通過查詢參數)并對解析的URL的主機執行驗證檢查時可能容易受到Open重定向攻擊和SSRF攻擊,導致網絡釣魚和內部網絡探測等。

受影響產品或系統

6.1.0 <= Spring Framework <= 6.1.3

6.0.0 <= Spring Framework <= 6.0.16

5.3.0 <= Spring Framework <= 5.3.31

官方建議修復方案

Spring?Framework?版本6.1.x 用戶:升級到 6.1.3

Spring?Framework?版本6.0.x 用戶:升級到 6.0.16

Spring??Framework?版本5.3.x 用戶:升級到 5.3.31

其它已經不受官方支持的版本(5.1.x,5.2.x)同樣受到影響,更新到受官方支持的安全版本。

那么springboot項目我們該怎么修復該漏洞呢?

查看 springboot的版本,只有最新的3.1.93.2.3 修復了該漏洞。

如果現有項目的大版本是3.x,直接升級即可,但是有些老項目還停留在2.x的版本,官方并沒有針對2.x發布新版本,從2.x直接升級到3.x,代價又比較大。

一開始我們嘗試直接替換spring-web的版本,但是只替換這一個包的話項目啟動會報錯,通過實踐和反復嘗試,我們對spring相關的jar包都進行了覆蓋,這樣可以保持springboot的版本號不變。具體覆蓋的jar包如下:

         <!-- spring-web 相關 begin --><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-aop</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-beans</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-expression</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jcl</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-oxm</artifactId><version>5.3.32</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>5.3.32</version></dependency><!-- spring-web相關 end -->

只需要將上述依賴添加到pom.xml文件中即可覆蓋springboot默認的版本,替換后效果如下:

項目啟動正常

如果啟動后訪問接口報錯,需要更換跨域配置,將corsConfiguration.addAllowedOrigin("*")替換為corsConfiguration.addAllowedOriginPattern("*");

好了,上面的操作都完成后,漏洞就修復了,接下來有需要的話可以慢慢的升級到大版本!

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

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

相關文章

Vue項目的快速搭建

Vue項目的快速搭建 一、下載并安裝node.js二、安裝Vue腳手架三、創建vue項目四、項目啟動五、VS Code下載安裝 一、下載并安裝node.js 首先確保已經安裝了Node.js。如果沒有安裝&#xff0c;可以去官網&#xff08;https://nodejs.org/&#xff09;下載并安裝最新版本的Node.j…

基于STC12C5A60S2系列1T 8051單片機的TM1638鍵盤數碼管模塊的數碼管顯示應用

基于STC12C5A60S2系列1T 8051單片機的TM1638鍵盤數碼管模塊的數碼管顯示應用 STC12C5A60S2系列1T 8051單片機管腳圖STC12C5A60S2系列1T 8051單片機I/O口各種不同工作模式及配置STC12C5A60S2系列1T 8051單片機I/O口各種不同工作模式介紹TM1638鍵盤數碼管模塊概述TM1638鍵盤數碼管…

mybatis-傳遞參數的方式

mybatis 傳遞參數的7種方法 在實際開發過程中&#xff0c;增刪改查操作都要涉及到請求參數的傳遞&#xff0c;今天這節就集中講下在mybatis中傳遞參數的7中方法 單個參數的傳遞很簡單沒有什么好將的&#xff0c;這里主要說下多個參數的傳遞 1、第一種方式 匿名參數 順序傳遞…

[electron]窗口 BrowserWindow

優雅的顯示窗口 const {app, BrowserWindow} require(electron);function createMainwindow(){const mainwindow new BrowserWindow({x: 300,y: 400,width: 600,height: 600,});mainwindow.loadFile(index.html); }app.on(ready, ()>{createMainwindow(); });對于這樣的代…

前端發起請求,后端模型需處理很久,怎樣設置前端直接完成請求響應,后端計算完在返回結果給前端?

在這種情況下&#xff0c;可以采用異步處理的方式來解決。具體步驟如下&#xff1a; 前端發起請求&#xff1a;前端向后端發送請求&#xff0c;但是不等待后端處理完成而是立即得到響應。 后端異步處理&#xff1a;后端接收到請求后&#xff0c;不立即進行處理&#xff0c;而是…

Codeforces Round 886 (Div. 4)----->E. Cardboard for Pictures

一&#xff0c;思路&#xff1a; 這題我們可以通過二分 w來直接得到答案&#xff0c;時間復雜度是nlogn的級別&#xff0c;但是這里有個很坑的地方&#xff0c;就是假如你用二分做&#xff0c;會面臨報 long long 的問題&#xff0c;但是問題不大&#xff0c;直接用 unsigned …

題目:金三銀四求職季:如何脫穎而出

題目&#xff1a;金三銀四求職季&#xff1a;如何脫穎而出 引言&#xff1a; 隨著春天的腳步漸近&#xff0c;對于許多程序員來說&#xff0c;一年中最繁忙、最重要的面試季節也隨之而來。金三銀四&#xff0c;即三月和四月&#xff0c;被廣大程序員視為求職的黃金時期。在這兩…

藍橋杯倒計時 41天 - KMP 算法

KMP算法 KMP算法是一種字符串匹配算法&#xff0c;用于匹配模式串P在文本串S中出現的所有位置。 例如S“ababac&#xff0c;P“aba”&#xff0c;那么出現的所有位置是13。 在初學KMP時&#xff0c;我們只需要記住和學會使用模板即可&#xff0c;對其原理只需簡單理解&#xff…

用Socks5代理游戲,繞過“網絡海關”去探險

1. 出海大冒險的開始 在游戲世界&#xff0c;就像在現實生活中一樣&#xff0c;有時我們需要越過海洋去探索未知的世界。但是&#xff0c;網絡上也有一些“海關”&#xff0c;限制我們訪問某些網站或游戲服務器。這就是我們今天要克服的挑戰&#xff01; 2. Socks5代理&#xf…

Django 官網項目 四

內容&#xff1a; 利用HTTP的post方法&#xff0c;更改數據并顯示。 創建detail.html文件&#xff0c;來創建POST內容 修改應用的視圖文件views.py&#xff0c;vote方法 修改應用的視圖文件views.py&#xff0c;results方法。 創建results.html文件。 結果&#xff1a;單…

.NET開源功能強大的串口調試工具

前言 今天大姚給大家分享一款.NET開源的、功能強大的串口調試工具&#xff1a;LLCOM。 工具介紹 LLCOM是一個.NET開源的、功能強大的串口調試工具。支持Lua自動化處理、串口調試、串口監聽、串口曲線、TCP測試、MQTT測試、編碼轉換、亂碼恢復等功能。 功能列表 收發日志清晰…

將SpringBoot項目改造成solon項目

solon項目介紹 官網 Java “生態型”應用開發框架&#xff1a;更快、更小、更簡單。 啟動快 5 &#xff5e; 10 倍&#xff1b;并發高 2&#xff5e; 3 倍&#xff1b; 內存省 1/3 ~ 1/2&#xff1b;打包縮到 1/2 ~ 1/10&#xff1b;同時支持 java8, java11, java17, java21&a…

數據結構學習(二)字符串

字符串 1. 概念 字符串就是特殊的字符數組&#xff0c;字符數組末尾的元素為 ‘\0’。和數組一樣可以使用arr[i]或*(arri)來訪問元素。 無論是用數組保存字符串&#xff08;如&#xff1a;char arr[] "Hello&#xff0c;World";&#xff09;&#xff0c;還是用指針…

漢諾塔問題(c++題解)

題目描述 1、一次只許移動一個盤 2、任何時候、任何柱子不允許把大盤放在小盤上面。 3、可使用任一一根立柱暫存圓盤。 問&#xff1a;如何使用最少步數實現n個盤子的移動&#xff1f;打印出具體移動方案。 輸入格式 一行一個數n, 1< n < 18 輸出格式 輸出若干行…

關于HTML5表單驗證的方法教程

簡介 HTML5表單驗證是一種在客戶端對用戶輸入進行驗證的方法&#xff0c;可以有效地減少對于服務器端驗證的依賴。通過使用HTML5表單驗證&#xff0c;可以為用戶提供實時的錯誤提示和更好的用戶體驗。本教程將介紹如何在HTML5中使用各種驗證屬性和技術來實現表單驗證。 基本表…

flynn發布服務小結

背景 flynn是一個基于容器的paas平臺&#xff0c;可以快速的發布運行新的應用&#xff0c;用戶只需要提交代碼到git上&#xff0c;flynn就會基于提交的代碼進行發布和部署&#xff0c;本文就簡單看下flynn發布部署的流程 flynn發布服務 1.首先flynn會基于用戶的web代碼構建一…

Nature 研究亮點(Volume 626 Issue 8001, 29 February 2024)

文章目錄 激光雕刻肥皂膜卵細胞的回收系統巴斯克語的起源產后抑郁癥的治療 激光雕刻肥皂膜 研究者&#xff1a;Haitao Xu 和 Yu Zhao&#xff0c;清華大學&#xff0c;北京。 發現&#xff1a;在特定條件下&#xff0c;可以使用激光在肥皂膜上進行雕刻。肥皂膜由洗滌劑分子&am…

AJAX 學習筆記(Day1)

「寫在前面」 本文為黑馬程序員 AJAX 教程的學習筆記。本著自己學習、分享他人的態度&#xff0c;分享學習筆記&#xff0c;希望能對大家有所幫助。 目錄 0 課程介紹 1 AJAX 入門 1.1 AJAX 概念和 axios 使用 1.2 認識 URL 1.3 URL 查詢參數 1.4 常用請求方法和數據提交 1.5 HT…

H264的打包,nal,es,pes,pts,dts,ps,ts

編碼層次 視頻編碼層&#xff1a;預測、變換、量化、熵編碼等操作slice層&#xff1a;將視頻幀分割成若干個編碼單元&#xff0c;包含一定數量的宏塊&#xff0c;提高編解碼的并行性和容錯性。NAL層&#xff1a;提升對網絡傳輸和數據存儲的親和性 視頻編碼層 基準-Baseline …

云計算與大數據課程筆記(一)云計算背景與介紹

如何實現一個簡易搜索引擎&#xff1f; 實現一個簡易的搜索引擎可以分為幾個基本步驟&#xff1a;數據收集&#xff08;爬蟲&#xff09;、數據處理&#xff08;索引&#xff09;、查詢處理和結果呈現。下面是一個概括的實現流程&#xff1a; 1. 數據收集&#xff08;爬蟲&am…