Project Reactor Security Advisories

Spring Boot Welcome Page DoS Vulnerability

MEDIUM | 10/19/2022 | CVE-2022-31684

Description

In Spring Boot versions 3.0.0 - 3.0.6, 2.7.0 - 2.7.11, 2.6.0 - 2.6.14, 2.5.0 - 2.5.14 and older unsupported versions, there is potential for a denial-of-service (DoS) attack if Spring MVC is used together with a reverse proxy cache.

Specifically, an application is vulnerable if all of the conditions are true:

The application has Spring MVC auto-configuration enabled. This is the case by default if Spring MVC is on the classpath. The application makes use of Spring Boot's welcome page support, either static or templated. Your application is deployed behind a proxy which caches 404 responses. Your application is NOT vulnerable if any of the following are true:

Spring MVC auto-configuration is disabled. This is true if WebMvcAutoConfiguration is explicitly excluded, if Spring MVC is not on the classpath, or if spring.main.web-application-type is set to a value other than SERVLET. The application does not use Spring Boot's welcome page support. You do not have a proxy which caches 404 responses.

Affected Spring Products and Versions

Spring Boot

3.0.0 to 3.0.6 2.7.0 to 2.7.11 2.6.0 to 2.6.14 2.5.0 to 2.5.14

Older, unsupported versions are also affected

Mitigation

Users of affected versions should apply the following mitigations:

3.0.x users should upgrade to 3.0.7+ 2.7.x users should upgrade to 2.7.12+ 2.6.x users should upgrade to 2.6.15+ 2.5.x users should upgrade to 2.5.15+ Users of older, unsupported versions should upgrade to 3.0.7+ or 2.7.12+.

Workarounds: configure the reverse proxy not to cache 404 responses and/or not to cache responses to requests to the root (/) of the application.

Credit

Martin van Kervel Smedshammer