Vulnerability Details CVE-2025-59471
A denial of service vulnerability exists in self-hosted Next.js applications that have `remotePatterns` configured for the Image Optimizer. The image optimization endpoint (`/_next/image`) loads external images entirely into memory without enforcing a maximum size limit, allowing an attacker to cause out-of-memory conditions by requesting optimization of arbitrarily large images. This vulnerability requires that `remotePatterns` is configured to allow image optimization from external domains and that the attacker can serve or control a large image on an allowed domain.
Strongly consider upgrading to 15.5.10 or 16.1.5 to reduce risk and prevent availability issues in Next applications.
Exploit prediction scoring system (EPSS) score
EPSS Score 0.001
EPSS Ranking 16.2%
CVSS Severity
CVSS v3 Score 5.9
Products affected by CVE-2025-59471
-
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.24
-
cpe:2.3:a:vercel:next.js:14.2.25
-
cpe:2.3:a:vercel:next.js:14.2.26
-
cpe:2.3:a:vercel:next.js:14.2.27
-
cpe:2.3:a:vercel:next.js:14.2.28
-
cpe:2.3:a:vercel:next.js:14.2.29
-
cpe:2.3:a:vercel:next.js:14.2.3
-
cpe:2.3:a:vercel:next.js:14.2.30
-
cpe:2.3:a:vercel:next.js:14.2.31
-
cpe:2.3:a:vercel:next.js:14.2.32
-
cpe:2.3:a:vercel:next.js:14.2.33
-
cpe:2.3:a:vercel:next.js:14.2.34
-
cpe:2.3:a:vercel:next.js:14.2.35
-
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:14.3.0
-
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.0.6
-
cpe:2.3:a:vercel:next.js:15.0.7
-
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.10
-
cpe:2.3:a:vercel:next.js:15.1.11
-
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:15.1.6
-
cpe:2.3:a:vercel:next.js:15.1.7
-
cpe:2.3:a:vercel:next.js:15.1.8
-
cpe:2.3:a:vercel:next.js:15.1.9
-
cpe:2.3:a:vercel:next.js:15.2.0
-
cpe:2.3:a:vercel:next.js:15.2.1
-
cpe:2.3:a:vercel:next.js:15.2.2
-
cpe:2.3:a:vercel:next.js:15.2.3
-
cpe:2.3:a:vercel:next.js:15.2.4
-
cpe:2.3:a:vercel:next.js:15.2.5
-
cpe:2.3:a:vercel:next.js:15.2.6
-
cpe:2.3:a:vercel:next.js:15.2.7
-
cpe:2.3:a:vercel:next.js:15.2.8
-
cpe:2.3:a:vercel:next.js:15.3.0
-
cpe:2.3:a:vercel:next.js:15.3.1
-
cpe:2.3:a:vercel:next.js:15.3.2
-
cpe:2.3:a:vercel:next.js:15.3.3
-
cpe:2.3:a:vercel:next.js:15.3.4
-
cpe:2.3:a:vercel:next.js:15.3.5
-
cpe:2.3:a:vercel:next.js:15.3.6
-
cpe:2.3:a:vercel:next.js:15.3.7
-
cpe:2.3:a:vercel:next.js:15.3.8
-
cpe:2.3:a:vercel:next.js:15.4.0
-
cpe:2.3:a:vercel:next.js:15.4.1
-
cpe:2.3:a:vercel:next.js:15.4.10
-
cpe:2.3:a:vercel:next.js:15.4.2
-
cpe:2.3:a:vercel:next.js:15.4.3
-
cpe:2.3:a:vercel:next.js:15.4.4
-
cpe:2.3:a:vercel:next.js:15.4.5
-
cpe:2.3:a:vercel:next.js:15.4.6
-
cpe:2.3:a:vercel:next.js:15.4.7
-
cpe:2.3:a:vercel:next.js:15.4.8
-
cpe:2.3:a:vercel:next.js:15.4.9
-
cpe:2.3:a:vercel:next.js:15.5.0
-
cpe:2.3:a:vercel:next.js:15.5.1
-
cpe:2.3:a:vercel:next.js:15.5.2
-
cpe:2.3:a:vercel:next.js:15.5.3
-
cpe:2.3:a:vercel:next.js:15.5.4
-
cpe:2.3:a:vercel:next.js:15.5.5
-
cpe:2.3:a:vercel:next.js:15.5.6
-
cpe:2.3:a:vercel:next.js:15.5.7
-
cpe:2.3:a:vercel:next.js:15.5.8
-
cpe:2.3:a:vercel:next.js:15.5.9
-
cpe:2.3:a:vercel:next.js:16.0.0
-
cpe:2.3:a:vercel:next.js:16.0.1
-
cpe:2.3:a:vercel:next.js:16.0.10
-
cpe:2.3:a:vercel:next.js:16.0.2
-
cpe:2.3:a:vercel:next.js:16.0.3
-
cpe:2.3:a:vercel:next.js:16.0.4
-
cpe:2.3:a:vercel:next.js:16.0.5
-
cpe:2.3:a:vercel:next.js:16.0.6
-
cpe:2.3:a:vercel:next.js:16.0.7
-
cpe:2.3:a:vercel:next.js:16.0.8
-
cpe:2.3:a:vercel:next.js:16.0.9
-
cpe:2.3:a:vercel:next.js:16.1.0
-
cpe:2.3:a:vercel:next.js:16.1.1
-
cpe:2.3:a:vercel:next.js:16.1.2
-
cpe:2.3:a:vercel:next.js:16.1.3
-
cpe:2.3:a:vercel:next.js:16.1.4