← voltar
CVE-2026-27980

Next.js: Unbounded next/image disk cache growth can exhaust storage

CVSS 6.9 MEDIUMEPSS 0.7%CWE-400
Em resumo

O Next.js armazena imagens otimizadas em cache no disco sem limite de tamanho, permitindo que um atacante encha o armazenamento do seu servidor solicitando muitas variações diferentes de imagens. Isso pode derrubar sua aplicação e deixar seu site indisponível.

Detalhe técnico

CVE-2026-27980 afeta Next.js versões 10.0.0 a 16.1.6 onde o diretório de cache `/_next/image` cresce ilimitadamente sem controle de limite. Um atacante pode explorar CWE-400 (Consumo Descontrolado de Recursos) criando requisições com parâmetros variados de otimização de imagens para esgotar o espaço em disco, resultando em negação de serviço. A mitigação requer atualização para 16.1.7+ que implementa remoção LRU via `images.maximumDiskCacheSize`, ou limpeza temporária de diretórios de cache e restrição de padrões de geração de variantes.

Resumo gerado e traduzido por IA a partir da descrição oficial.
Next.js is a React framework for building full-stack web applications. Starting in version 10.0.0 and prior to version 16.1.7, the default Next.js image optimization disk cache (`/_next/image`) did not have a configurable upper bound, allowing unbounded cache growth. An attacker could generate many unique image-optimization variants and exhaust disk space, causing denial of service. This is fixed in version 16.1.7 by adding an LRU-backed disk cache with `images.maximumDiskCacheSize`, including eviction of least-recently-used entries when the limit is exceeded. Setting `maximumDiskCacheSize: 0` disables disk caching. If upgrading is not immediately possible, periodically clean `.next/cache/images` and/or reduce variant cardinality (e.g., tighten values for `images.localPatterns`, `images.remotePatterns`, and `images.qualities`).
CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:L/SC:N/SI:N/SA:N
Produtos afetados
vercel · next.js

Quer saber se a sua infraestrutura está exposta a isto?

Falar com a TrueHacking →