Vulnerability Details CVE-2025-32421
Next.js is a React framework for building full-stack web applications. Versions prior to 14.2.24 and 15.1.6 have a race-condition vulnerability. This issue only affects the Pages Router under certain misconfigurations, causing normal endpoints to serve `pageProps` data instead of standard HTML. This issue was patched in versions 15.1.6 and 14.2.24 by stripping the `x-now-route-matches` header from incoming requests. Applications hosted on Vercel's platform are not affected by this issue, as the platform does not cache responses based solely on `200 OK` status without explicit `cache-control` headers. Those who self-host Next.js deployments and are unable to upgrade immediately can mitigate this vulnerability by stripping the `x-now-route-matches` header from all incoming requests at the content development network and setting `cache-control: no-store` for all responses under risk. The maintainers of Next.js strongly recommend only caching responses with explicit cache-control headers.
Exploit prediction scoring system (EPSS) score
EPSS Score 0.0
EPSS Ranking 12.7%
CVSS Severity
CVSS v3 Score 3.7
Products affected by CVE-2025-32421
-
cpe:2.3:a:vercel:next.js:1.0.0
-
cpe:2.3:a:vercel:next.js:1.0.1
-
cpe:2.3:a:vercel:next.js:1.0.2
-
cpe:2.3:a:vercel:next.js:1.1.0
-
cpe:2.3:a:vercel:next.js:1.1.1
-
cpe:2.3:a:vercel:next.js:1.1.2
-
cpe:2.3:a:vercel:next.js:1.2.0
-
cpe:2.3:a:vercel:next.js:1.2.1
-
cpe:2.3:a:vercel:next.js:1.2.2
-
cpe:2.3:a:vercel:next.js:1.2.3
-
cpe:2.3:a:vercel:next.js:10.0.0
-
cpe:2.3:a:vercel:next.js:10.0.1
-
cpe:2.3:a:vercel:next.js:10.0.10
-
cpe:2.3:a:vercel:next.js:10.0.2
-
cpe:2.3:a:vercel:next.js:10.0.3
-
cpe:2.3:a:vercel:next.js:10.0.4
-
cpe:2.3:a:vercel:next.js:10.0.5
-
cpe:2.3:a:vercel:next.js:10.0.6
-
cpe:2.3:a:vercel:next.js:10.0.7
-
cpe:2.3:a:vercel:next.js:10.0.8
-
cpe:2.3:a:vercel:next.js:10.0.9
-
cpe:2.3:a:vercel:next.js:10.1.0
-
cpe:2.3:a:vercel:next.js:10.1.1
-
cpe:2.3:a:vercel:next.js:10.1.2
-
cpe:2.3:a:vercel:next.js:10.1.3
-
cpe:2.3:a:vercel:next.js:10.1.4
-
cpe:2.3:a:vercel:next.js:10.2.0
-
cpe:2.3:a:vercel:next.js:10.2.1
-
cpe:2.3:a:vercel:next.js:10.2.2
-
cpe:2.3:a:vercel:next.js:10.2.3
-
cpe:2.3:a:vercel:next.js:10.2.4
-
cpe:2.3:a:vercel:next.js:11.0.0
-
cpe:2.3:a:vercel:next.js:11.0.1
-
cpe:2.3:a:vercel:next.js:11.0.2
-
cpe:2.3:a:vercel:next.js:11.1.0
-
cpe:2.3:a:vercel:next.js:11.1.1
-
cpe:2.3:a:vercel:next.js:11.1.2
-
cpe:2.3:a:vercel:next.js:11.1.3
-
cpe:2.3:a:vercel:next.js:11.1.4
-
cpe:2.3:a:vercel:next.js:12.0.0
-
cpe:2.3:a:vercel:next.js:12.0.1
-
cpe:2.3:a:vercel:next.js:12.0.10
-
cpe:2.3:a:vercel:next.js:12.0.11
-
cpe:2.3:a:vercel:next.js:12.0.2
-
cpe:2.3:a:vercel:next.js:12.0.3
-
cpe:2.3:a:vercel:next.js:12.0.4
-
cpe:2.3:a:vercel:next.js:12.0.5
-
cpe:2.3:a:vercel:next.js:12.0.6
-
cpe:2.3:a:vercel:next.js:12.0.7
-
cpe:2.3:a:vercel:next.js:12.0.8
-
cpe:2.3:a:vercel:next.js:12.0.9
-
cpe:2.3:a:vercel:next.js:12.1.0
-
cpe:2.3:a:vercel:next.js:12.1.1
-
cpe:2.3:a:vercel:next.js:12.1.2
-
cpe:2.3:a:vercel:next.js:12.1.3
-
cpe:2.3:a:vercel:next.js:12.1.4
-
cpe:2.3:a:vercel:next.js:12.1.5
-
cpe:2.3:a:vercel:next.js:12.1.6
-
cpe:2.3:a:vercel:next.js:12.1.7
-
cpe:2.3:a:vercel:next.js:12.2.0
-
cpe:2.3:a:vercel:next.js:12.2.1
-
cpe:2.3:a:vercel:next.js:12.2.2
-
cpe:2.3:a:vercel:next.js:12.2.3
-
cpe:2.3:a:vercel:next.js:12.2.4
-
cpe:2.3:a:vercel:next.js:12.2.5
-
cpe:2.3:a:vercel:next.js:12.2.6
-
cpe:2.3:a:vercel:next.js:12.3.0
-
cpe:2.3:a:vercel:next.js:12.3.1
-
cpe:2.3:a:vercel:next.js:12.3.2
-
cpe:2.3:a:vercel:next.js:12.3.3
-
cpe:2.3:a:vercel:next.js:12.3.4
-
cpe:2.3:a:vercel:next.js:12.3.5
-
cpe:2.3:a:vercel:next.js:12.3.6
-
cpe:2.3:a:vercel:next.js:12.3.7
-
cpe:2.3:a:vercel:next.js:13.0.0
-
cpe:2.3:a:vercel:next.js:13.0.1
-
cpe:2.3:a:vercel:next.js:13.0.2
-
cpe:2.3:a:vercel:next.js:13.0.3
-
cpe:2.3:a:vercel:next.js:13.0.4
-
cpe:2.3:a:vercel:next.js:13.0.5
-
cpe:2.3:a:vercel:next.js:13.0.6
-
cpe:2.3:a:vercel:next.js:13.0.7
-
cpe:2.3:a:vercel:next.js:13.0.8
-
cpe:2.3:a:vercel:next.js:13.1.0
-
cpe:2.3:a:vercel:next.js:13.1.1
-
cpe:2.3:a:vercel:next.js:13.1.2
-
cpe:2.3:a:vercel:next.js:13.1.3
-
cpe:2.3:a:vercel:next.js:13.1.4
-
cpe:2.3:a:vercel:next.js:13.1.5
-
cpe:2.3:a:vercel:next.js:13.1.6
-
cpe:2.3:a:vercel:next.js:13.1.7
-
cpe:2.3:a:vercel:next.js:13.2.0
-
cpe:2.3:a:vercel:next.js:13.2.1
-
cpe:2.3:a:vercel:next.js:13.2.2
-
cpe:2.3:a:vercel:next.js:13.2.3
-
cpe:2.3:a:vercel:next.js:13.2.4
-
cpe:2.3:a:vercel:next.js:13.2.5
-
cpe:2.3:a:vercel:next.js:13.3.0
-
cpe:2.3:a:vercel:next.js:13.3.1
-
cpe:2.3:a:vercel:next.js:13.3.2
-
cpe:2.3:a:vercel:next.js:13.3.3
-
cpe:2.3:a:vercel:next.js:13.3.4
-
cpe:2.3:a:vercel:next.js:13.3.5
-
cpe:2.3:a:vercel:next.js:13.4.0
-
cpe:2.3:a:vercel:next.js:13.4.1
-
cpe:2.3:a:vercel:next.js:13.4.10
-
cpe:2.3:a:vercel:next.js:13.4.11
-
cpe:2.3:a:vercel:next.js:13.4.12
-
cpe:2.3:a:vercel:next.js:13.4.13
-
cpe:2.3:a:vercel:next.js:13.4.14
-
cpe:2.3:a:vercel:next.js:13.4.15
-
cpe:2.3:a:vercel:next.js:13.4.16
-
cpe:2.3:a:vercel:next.js:13.4.17
-
cpe:2.3:a:vercel:next.js:13.4.18
-
cpe:2.3:a:vercel:next.js:13.4.19
-
cpe:2.3:a:vercel:next.js:13.4.2
-
cpe:2.3:a:vercel:next.js:13.4.20
-
cpe:2.3:a:vercel:next.js:13.4.3
-
cpe:2.3:a:vercel:next.js:13.4.4
-
cpe:2.3:a:vercel:next.js:13.4.5
-
cpe:2.3:a:vercel:next.js:13.4.6
-
cpe:2.3:a:vercel:next.js:13.4.7
-
cpe:2.3:a:vercel:next.js:13.4.8
-
cpe:2.3:a:vercel:next.js:13.4.9
-
cpe:2.3:a:vercel:next.js:13.5.0
-
cpe:2.3:a:vercel:next.js:13.5.1
-
cpe:2.3:a:vercel:next.js:13.5.10
-
cpe:2.3:a:vercel:next.js:13.5.11
-
cpe:2.3:a:vercel:next.js:13.5.2
-
cpe:2.3:a:vercel:next.js:13.5.3
-
cpe:2.3:a:vercel:next.js:13.5.4
-
cpe:2.3:a:vercel:next.js:13.5.5
-
cpe:2.3:a:vercel:next.js:13.5.6
-
cpe:2.3:a:vercel:next.js:13.5.7
-
cpe:2.3:a:vercel:next.js:13.5.8
-
cpe:2.3:a:vercel:next.js:13.5.9
-
cpe:2.3:a:vercel:next.js:14.0.0
-
cpe:2.3:a:vercel:next.js:14.0.1
-
cpe:2.3:a:vercel:next.js:14.0.2
-
cpe:2.3:a:vercel:next.js:14.0.3
-
cpe:2.3:a:vercel:next.js:14.0.4
-
cpe:2.3:a:vercel:next.js:14.0.5
-
cpe:2.3:a:vercel:next.js:14.1.0
-
cpe:2.3:a:vercel:next.js:14.1.1
-
cpe:2.3:a:vercel:next.js:14.1.2
-
cpe:2.3:a:vercel:next.js:14.1.3
-
cpe:2.3:a:vercel:next.js:14.1.4
-
cpe:2.3:a:vercel:next.js:14.2.0
-
cpe:2.3:a:vercel:next.js:14.2.1
-
cpe:2.3:a:vercel:next.js:14.2.10
-
cpe:2.3:a:vercel:next.js:14.2.11
-
cpe:2.3:a:vercel:next.js:14.2.12
-
cpe:2.3:a:vercel:next.js:14.2.13
-
cpe:2.3:a:vercel:next.js:14.2.14
-
cpe:2.3:a:vercel:next.js:14.2.15
-
cpe:2.3:a:vercel:next.js:14.2.16
-
cpe:2.3:a:vercel:next.js:14.2.17
-
cpe:2.3:a:vercel:next.js:14.2.18
-
cpe:2.3:a:vercel:next.js:14.2.19
-
cpe:2.3:a:vercel:next.js:14.2.20
-
cpe:2.3:a:vercel:next.js:14.2.21
-
cpe:2.3:a:vercel:next.js:14.2.22
-
cpe:2.3:a:vercel:next.js:14.2.23
-
cpe:2.3:a:vercel:next.js:14.2.3
-
cpe:2.3:a:vercel:next.js:14.2.4
-
cpe:2.3:a:vercel:next.js:14.2.5
-
cpe:2.3:a:vercel:next.js:14.2.6
-
cpe:2.3:a:vercel:next.js:14.2.7
-
cpe:2.3:a:vercel:next.js:14.2.8
-
cpe:2.3:a:vercel:next.js:14.2.9
-
cpe:2.3:a:vercel:next.js:15.0.0
-
cpe:2.3:a:vercel:next.js:15.0.1
-
cpe:2.3:a:vercel:next.js:15.0.2
-
cpe:2.3:a:vercel:next.js:15.0.3
-
cpe:2.3:a:vercel:next.js:15.0.4
-
cpe:2.3:a:vercel:next.js:15.0.5
-
cpe:2.3:a:vercel:next.js:15.1.0
-
cpe:2.3:a:vercel:next.js:15.1.1
-
cpe:2.3:a:vercel:next.js:15.1.2
-
cpe:2.3:a:vercel:next.js:15.1.3
-
cpe:2.3:a:vercel:next.js:15.1.4
-
cpe:2.3:a:vercel:next.js:15.1.5
-
cpe:2.3:a:vercel:next.js:2.0.0
-
cpe:2.3:a:vercel:next.js:2.0.1
-
cpe:2.3:a:vercel:next.js:2.1.0
-
cpe:2.3:a:vercel:next.js:2.1.1
-
cpe:2.3:a:vercel:next.js:2.2.0
-
cpe:2.3:a:vercel:next.js:2.3
-
cpe:2.3:a:vercel:next.js:2.3.0
-
cpe:2.3:a:vercel:next.js:2.3.1
-
cpe:2.3:a:vercel:next.js:2.3.2
-
cpe:2.3:a:vercel:next.js:2.4.0
-
cpe:2.3:a:vercel:next.js:2.4.1
-
cpe:2.3:a:vercel:next.js:2.4.2
-
cpe:2.3:a:vercel:next.js:2.4.3
-
cpe:2.3:a:vercel:next.js:2.4.4
-
cpe:2.3:a:vercel:next.js:2.4.5
-
cpe:2.3:a:vercel:next.js:2.4.6
-
cpe:2.3:a:vercel:next.js:2.4.7
-
cpe:2.3:a:vercel:next.js:2.4.8
-
cpe:2.3:a:vercel:next.js:2.4.9
-
cpe:2.3:a:vercel:next.js:3.0.0
-
cpe:2.3:a:vercel:next.js:3.0.1
-
cpe:2.3:a:vercel:next.js:3.0.2
-
cpe:2.3:a:vercel:next.js:3.0.3
-
cpe:2.3:a:vercel:next.js:3.0.4
-
cpe:2.3:a:vercel:next.js:3.0.5
-
cpe:2.3:a:vercel:next.js:3.0.6
-
cpe:2.3:a:vercel:next.js:3.1.0
-
cpe:2.3:a:vercel:next.js:3.2.0
-
cpe:2.3:a:vercel:next.js:3.2.1
-
cpe:2.3:a:vercel:next.js:3.2.2
-
cpe:2.3:a:vercel:next.js:3.2.3
-
cpe:2.3:a:vercel:next.js:4.0.0
-
cpe:2.3:a:vercel:next.js:4.0.1
-
cpe:2.3:a:vercel:next.js:4.0.2
-
cpe:2.3:a:vercel:next.js:4.0.3
-
cpe:2.3:a:vercel:next.js:4.0.4
-
cpe:2.3:a:vercel:next.js:4.0.5
-
cpe:2.3:a:vercel:next.js:4.1.0
-
cpe:2.3:a:vercel:next.js:4.1.1
-
cpe:2.3:a:vercel:next.js:4.1.2
-
cpe:2.3:a:vercel:next.js:4.1.3
-
cpe:2.3:a:vercel:next.js:4.1.4
-
cpe:2.3:a:vercel:next.js:4.2.0
-
cpe:2.3:a:vercel:next.js:4.2.1
-
cpe:2.3:a:vercel:next.js:4.2.2
-
cpe:2.3:a:vercel:next.js:4.2.3
-
cpe:2.3:a:vercel:next.js:4.3.0
-
cpe:2.3:a:vercel:next.js:4.4.0
-
cpe:2.3:a:vercel:next.js:5.0.0
-
cpe:2.3:a:vercel:next.js:5.0.1
-
cpe:2.3:a:vercel:next.js:5.1.0
-
cpe:2.3:a:vercel:next.js:6.0.0
-
cpe:2.3:a:vercel:next.js:6.0.1
-
cpe:2.3:a:vercel:next.js:6.0.2
-
cpe:2.3:a:vercel:next.js:6.0.3
-
cpe:2.3:a:vercel:next.js:6.0.4
-
cpe:2.3:a:vercel:next.js:6.1.0
-
cpe:2.3:a:vercel:next.js:6.1.1
-
cpe:2.3:a:vercel:next.js:6.1.2
-
cpe:2.3:a:vercel:next.js:7.0.0
-
cpe:2.3:a:vercel:next.js:7.0.1
-
cpe:2.3:a:vercel:next.js:7.0.2
-
cpe:2.3:a:vercel:next.js:7.0.3
-
cpe:2.3:a:vercel:next.js:8.0.0
-
cpe:2.3:a:vercel:next.js:8.0.1
-
cpe:2.3:a:vercel:next.js:8.0.2
-
cpe:2.3:a:vercel:next.js:8.0.3
-
cpe:2.3:a:vercel:next.js:8.0.4
-
cpe:2.3:a:vercel:next.js:8.0.5
-
cpe:2.3:a:vercel:next.js:8.1.1
-
cpe:2.3:a:vercel:next.js:9.0.0
-
cpe:2.3:a:vercel:next.js:9.0.1
-
cpe:2.3:a:vercel:next.js:9.0.2
-
cpe:2.3:a:vercel:next.js:9.0.3
-
cpe:2.3:a:vercel:next.js:9.0.4
-
cpe:2.3:a:vercel:next.js:9.0.5
-
cpe:2.3:a:vercel:next.js:9.0.6
-
cpe:2.3:a:vercel:next.js:9.0.7
-
cpe:2.3:a:vercel:next.js:9.0.8
-
cpe:2.3:a:vercel:next.js:9.0.9
-
cpe:2.3:a:vercel:next.js:9.1.0
-
cpe:2.3:a:vercel:next.js:9.1.1
-
cpe:2.3:a:vercel:next.js:9.1.2
-
cpe:2.3:a:vercel:next.js:9.1.3
-
cpe:2.3:a:vercel:next.js:9.1.4
-
cpe:2.3:a:vercel:next.js:9.1.5
-
cpe:2.3:a:vercel:next.js:9.1.6
-
cpe:2.3:a:vercel:next.js:9.1.7
-
cpe:2.3:a:vercel:next.js:9.1.8
-
cpe:2.3:a:vercel:next.js:9.2.0
-
cpe:2.3:a:vercel:next.js:9.2.1
-
cpe:2.3:a:vercel:next.js:9.2.2
-
cpe:2.3:a:vercel:next.js:9.2.3
-
cpe:2.3:a:vercel:next.js:9.3.0
-
cpe:2.3:a:vercel:next.js:9.3.1
-
cpe:2.3:a:vercel:next.js:9.3.2
-
cpe:2.3:a:vercel:next.js:9.3.3
-
cpe:2.3:a:vercel:next.js:9.3.4
-
cpe:2.3:a:vercel:next.js:9.3.5
-
cpe:2.3:a:vercel:next.js:9.5.0
-
cpe:2.3:a:vercel:next.js:9.5.1
-
cpe:2.3:a:vercel:next.js:9.5.2
-
cpe:2.3:a:vercel:next.js:9.5.3
-
cpe:2.3:a:vercel:next.js:9.5.4
-
cpe:2.3:a:vercel:next.js:9.5.5
-
cpe:2.3:a:vercel:next.js:9.5.6