CVE-2026-45416

HIGH

Netty: SNI handler pre-allocates up to 16 MiB from nine attacker bytes

Title source: cna
STIX 2.1

Description

Netty is a network application framework for development of protocol servers and clients. Prior to versions 4.1.135.Final and 4.2.15.Final, SslClientHelloHandler.decode() reads the 24-bit TLS handshake length and, when the ClientHello does not fit in the first record, eagerly allocates `ctx.alloc().buffer(handshakeLength)` (line 161). The guard at line 140 is `handshakeLength > maxClientHelloLength && maxClientHelloLength != 0`, and the commonly-used SniHandler/AbstractSniHandler constructors (SniHandler(Mapping), SniHandler(AsyncMapping), AbstractSniHandler()) pass maxClientHelloLength=0 and handshakeTimeoutMillis=0, so the length guard is disabled and no timeout is scheduled. A 16 MiB request exceeds the default pooled chunk size and becomes a huge/unpooled allocation performed immediately. The buffer is retained in the handler until the channel closes. Versions 4.1.135.Final and 4.2.15.Final patch the issue.

References (3)

Core 3

Scores

CVSS v3 7.5
EPSS 0.0061
EPSS Percentile 44.3%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

CISA SSVC

Vulnrichment
Exploitation none
Automatable yes
Technical Impact partial

Details

CWE
CWE-770
Status published
Products (5)
io.netty/netty-handler 0 - 4.1.135.FinalMaven
io.netty/netty-handler 4.2.0.Final - 4.2.15.FinalMaven
netty/netty < 4.1.135
netty/netty < 4.1.135.Final
netty/netty >= 4.2.0.Final, < 4.2.15.Final
Published Jun 12, 2026
Tracked Since Jun 12, 2026