216.73.217.22

CVE-2026-31842

· Published 07/04/2026 12:16 · Modified 07/04/2026 13:20

Labels: CVE-2026-31842 2026-04-07309f9ea4-e3e9-4c6c-b79d-e8eb01244f2cCVE-2026-31842CWE-444

Essential information

Published
07/04/2026 12:16
Modified
07/04/2026 13:20
Author
Creator
CVSS
8.7 HIGH (v3) 8.7 HIGH (v4.0)
CISA KEV
No
CWE
CVSS vector

CVSS metrics

Description

Tinyproxy through 1.11.3 is vulnerable to HTTP request parsing desynchronization due to a case-sensitive comparison of the Transfer-Encoding header in src/reqs.c. The is_chunked_transfer() function uses strcmp() to compare the header value against "chunked", even though RFC 7230 specifies that transfer-coding names are case-insensitive. By sending a request with Transfer-Encoding: Chunked, an unauthenticated remote attacker can cause Tinyproxy to misinterpret the request as having no body. In this state, Tinyproxy sets content_length.client to -1, skips pull_client_data_chunked(), forwards request headers upstream, and transitions into relay_connection() raw TCP forwarding while unread body data remains buffered. This leads to inconsistent request state between Tinyproxy and backend servers. RFC-compliant backends (e.g., Node.js, Nginx) will continue waiting for chunked body data, causing connections to hang indefinitely. This behavior enables application-level denial of service through backend worker exhaustion. Additionally, in deployments where Tinyproxy is used for request-body inspection, filtering, or security enforcement, the unread body may be forwarded without proper inspection, resulting in potential security control bypass.

NVD status

Status
Undergoing Analysis — CVE has been recently published to the CVE List and has been received by the NVD.
Source
309f9ea4-e3e9-4c6c-b79d-e8eb01244f2c
NVD
View on NVD

Affected products (CPE)

ProductCPE
tinyproxy / tinyproxy cpe:2.3:a:tinyproxy:tinyproxy:1.11.3:*:*:*:*:*:*:*
tinyproxy / tinyproxy cpe:2.3:a:tinyproxy:tinyproxy:<1.11.3:*:*:*:*:*:*:*

References