漏洞描述
当应用程序使用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.4
Spring Framework 版本6.0.x 用户:升级到 6.0.17
Spring Framework 版本5.3.x 用户:升级到 5.3.32
其它已经不受官方支持的版本(5.1.x,5.2.x)同样受到影响,更新到受官方支持的安全版本。
那么springboot项目我们该怎么修复该漏洞呢?
如果现有项目的大版本是3.x,直接升级到最新版本即可,但是有些老项目还停留在2.x的版本,官方并没有针对2.x发布新版本,从2.x直接升级到3.x,代价又比较大。
一开始我们尝试直接替换spring-web的版本,但是只替换这一个包的话项目启动会报错,通过实践和反复尝试,我们对spring相关的jar包都进行了覆盖,这样可以保持springboot的版本号不变。具体覆盖的jar包如下:
org.springframework spring-web5.3.32 org.springframework spring-webmvc5.3.32 org.springframework spring-aop5.3.32 org.springframework spring-beans5.3.32 org.springframework spring-context5.3.32 org.springframework spring-context-support5.3.32 org.springframework spring-core5.3.32 org.springframework spring-expression5.3.32 org.springframework spring-jcl5.3.32 org.springframework spring-jdbc5.3.32 org.springframework spring-oxm5.3.32 org.springframework spring-tx5.3.32
只需要将上述依赖添加到pom.xml文件中即可覆盖springboot默认的版本,替换后效果如下:
项目启动正常
如果启动后访问接口报错,需要更换跨域配置,将corsConfiguration.addAllowedOrigin("*")替换为corsConfiguration.addAllowedOriginPattern("*");
好了,上面的操作都完成后,漏洞就修复了,接下来有需要的话可以慢慢的升级到大版本!