Уязвимость контрабанды HTTP-запросов (CWE-444) была обнаружена при анализе запросов HTTP/1.0 и Transfer-Encoding в Pingora. Проблема возникает из-за неправильного разделения тел запросов HTTP/1.0 и неправильной обработки нескольких значений Transfer-Encoding, что позволяет злоумышленникам отправлять запросы HTTP/1.0 таким образом, что это приведет к десинхронизации кадра запроса Pingora с внутренними серверами. Воздействие Эта уязвимость в первую очередь затрагивает автономные развертывания Pingora перед определенными серверными модулями, которые принимают запросы HTTP/1.0.
Злоумышленник может создать вредоносную полезную нагрузку после этого запроса, который Pingora пересылает на серверную часть, чтобы:
* Обход элементов управления ACL на уровне прокси и логики WAF.
* Отравляют кэши и восходящие соединения, из-за чего последующие запросы от законных пользователей получают ответы, предназначенные для контрабандных запросов.
* Выполнять межпользовательские атаки путем перехвата сеансов или контрабанды запросов, которые, как представляется, исходят от доверенного IP-адреса прокси-сервера. Инфраструктура CDN Cloudflare не была затронута этой уязвимостью, поскольку ее входные прокси-уровни пересылали только запросы HTTP/1.1, отклоняли неоднозначные кадры, такие как недопустимые значения Content-Length, и пересылали один заголовок Transfer-Encoding: chunked для фрагментированных запросов. Смягчение:
Пользователям Pingora следует перейти на Pingora v0.8.0 или выше, которая устраняет эту проблему за счет правильного анализа заголовков длины сообщения в соответствии с RFC 9112 и строгого соблюдения дополнительных рекомендаций RFC, включая то, что тела HTTP-запросов никогда не должны быть разделены близкими разделителями.
В качестве обходного пути пользователи могут отклонять определенные запросы с ошибкой в логике фильтра запросов, чтобы остановить обработку байтов в соединении и отключить повторное использование нисходящего соединения. Пользователь должен отклонить любой запрос, отличный от HTTP/1.1, или запрос с недопустимой длиной содержимого, несколькими заголовками Transfer-Encoding или заголовком Transfer-Encoding, который не является точным совпадением «кусковой» строки.
Показать оригинальное описание (EN)
An HTTP Request Smuggling vulnerability (CWE-444) has been found in Pingora's parsing of HTTP/1.0 and Transfer-Encoding requests. The issue occurs due to improperly allowing HTTP/1.0 request bodies to be close-delimited and incorrect handling of multiple Transfer-Encoding values, allowing attackers to send HTTP/1.0 requests in a way that would desync Pingora’s request framing from backend servers’. Impact This vulnerability primarily affects standalone Pingora deployments in front of certain backends that accept HTTP/1.0 requests. An attacker could craft a malicious payload following this request that Pingora forwards to the backend in order to: * Bypass proxy-level ACL controls and WAF logic * Poison caches and upstream connections, causing subsequent requests from legitimate users to receive responses intended for smuggled requests * Perform cross-user attacks by hijacking sessions or smuggling requests that appear to originate from the trusted proxy IP Cloudflare's CDN infrastructure was not affected by this vulnerability, as its ingress proxy layers forwarded HTTP/1.1 requests only, rejected ambiguous framing such as invalid Content-Length values, and forwarded a single Transfer-Encoding: chunked header for chunked requests. Mitigation: Pingora users should upgrade to Pingora v0.8.0 or higher that fixes this issue by correctly parsing message length headers per RFC 9112 and strictly adhering to more RFC guidelines, including that HTTP request bodies are never close-delimited. As a workaround, users can reject certain requests with an error in the request filter logic in order to stop processing bytes on the connection and disable downstream connection reuse. The user should reject any non-HTTP/1.1 request, or a request that has invalid Content-Length, multiple Transfer-Encoding headers, or Transfer-Encoding header that is not an exact “chunked” string match.
Характеристики атаки
Последствия
Строка CVSS v4.0