CVE-2025-66199

NONE EPSS 0.07%
Обновлено 27 января 2026
OpenSSL
Параметр Значение
Тип уязвимости CWE-789
Поставщик OpenSSL
Публичный эксплойт Нет

Краткое описание проблемы. Соединение TLS 1.3 с использованием сжатия сертификатов может быть вынужден выделять большой буфер перед распаковкой без проверки в соответствии с настроенным ограничением размера сертификата. Краткое описание воздействия.

Злоумышленник может вызвать выделение памяти для каждого соединения. примерно до 22 МБ и дополнительная нагрузка на ЦП, что потенциально может привести к ухудшение качества обслуживания или истощение ресурсов (отказ в обслуживании). В затронутых конфигурациях несжатый сертификат, предоставленный одноранговым узлом. длина из сообщения CompressedCertificate используется для увеличения буфера кучи до декомпрессии. Эта длина не ограничена max_cert_list. параметр, который в противном случае ограничивает размеры сообщений сертификата.

Злоумышленник может использовать это, чтобы вызвать большие выделения для каждого соединения, за которыми следуют сбой рукопожатия. Никакого повреждения памяти или раскрытия информации не происходит. Эта проблема затрагивает только сборки, в которых используется сжатие сертификата TLS 1.3. скомпилирован (т. е. не OPENSSL_NO_COMP_ALG) и хотя бы одно сжатие доступен алгоритм (brotli, zlib или zstd), и где сжатие Продление оговаривается.

Оба клиента получают сервер CompressedCertificate. и серверы в сценариях взаимного TLS, получающие клиентский CompressedCertificate затронуты. Серверы, которые не запрашивают клиентские сертификаты, не уязвимы для атак, инициированных клиентом. Пользователи могут решить эту проблему, установив SSL_OP_NO_RX_CERTIFICATE_COMPRESSION. отключить получение сжатых сертификатов.

Модули FIPS версий 3.6, 3.5, 3.4 и 3.3 не затронуты этой проблемой. поскольку реализация TLS находится за пределами модуля OpenSSL FIPS. OpenSSL 3.6, 3.5, 3.4 и 3.3 уязвимы для этой проблемы. OpenSSL 3.0, 1.1.1 и 1.0.2 не подвержены этой проблеме.

Показать оригинальное описание (EN)

Issue summary: A TLS 1.3 connection using certificate compression can be forced to allocate a large buffer before decompression without checking against the configured certificate size limit. Impact summary: An attacker can cause per-connection memory allocations of up to approximately 22 MiB and extra CPU work, potentially leading to service degradation or resource exhaustion (Denial of Service). In affected configurations, the peer-supplied uncompressed certificate length from a CompressedCertificate message is used to grow a heap buffer prior to decompression. This length is not bounded by the max_cert_list setting, which otherwise constrains certificate message sizes. An attacker can exploit this to cause large per-connection allocations followed by handshake failure. No memory corruption or information disclosure occurs. This issue only affects builds where TLS 1.3 certificate compression is compiled in (i.e., not OPENSSL_NO_COMP_ALG) and at least one compression algorithm (brotli, zlib, or zstd) is available, and where the compression extension is negotiated. Both clients receiving a server CompressedCertificate and servers in mutual TLS scenarios receiving a client CompressedCertificate are affected. Servers that do not request client certificates are not vulnerable to client-initiated attacks. Users can mitigate this issue by setting SSL_OP_NO_RX_CERTIFICATE_COMPRESSION to disable receiving compressed certificates. The FIPS modules in 3.6, 3.5, 3.4 and 3.3 are not affected by this issue, as the TLS implementation is outside the OpenSSL FIPS module boundary. OpenSSL 3.6, 3.5, 3.4 and 3.3 are vulnerable to this issue. OpenSSL 3.0, 1.1.1 and 1.0.2 are not affected by this issue.

Тип уязвимости (CWE)