Advisory Database
  • Advisories
  • Dependency Scanning
  1. cargo
  2. ›
  3. async-h1
  4. ›
  5. CVE-2020-26281

CVE-2020-26281: Async-h1 request smuggling possible with long unread bodies

October 12, 2021

This vulnerability affects any webserver that uses async-h1 behind a reverse proxy, including all such Tide applications.

If the server does not read the body of a request which is longer than some buffer length, async-h1 will attempt to read a subsequent request from the body content starting at that offset into the body.

One way to exploit this vulnerability would be for an adversary to craft a request such that the body contains a request that would not be noticed by a reverse proxy, allowing it to forge forwarded/x-forwarded headers. If an application trusted the authenticity of these headers, it could be misled by the smuggled request.

Another potential concern with this vulnerability is that if a reverse proxy is sending multiple http clients’ requests along the same keep-alive connection, it would be possible for the smuggled request to specify a long content and capture another user’s request in its body. This content could be captured in a post request to an endpoint that allows the content to be subsequently retrieved by the adversary.

References

  • github.com/advisories/GHSA-4vr9-8cjf-vf9c
  • github.com/http-rs/async-h1
  • github.com/http-rs/async-h1/releases/tag/v2.3.0
  • github.com/http-rs/async-h1/security/advisories/GHSA-4vr9-8cjf-vf9c
  • nvd.nist.gov/vuln/detail/CVE-2020-26281
  • rustsec.org/advisories/RUSTSEC-2020-0093.html

Code Behaviors & Features

Detect and mitigate CVE-2020-26281 with GitLab Dependency Scanning

Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →

Affected versions

All versions before 2.3.0

Fixed versions

  • 2.3.0

Solution

Upgrade to version 2.3.0 or above.

Impact 6.8 MEDIUM

CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:C/C:N/I:H/A:N

Learn more about CVSS

Weakness

  • CWE-444: Inconsistent Interpretation of HTTP Requests ('HTTP Request/Response Smuggling')

Source file

cargo/async-h1/CVE-2020-26281.yml

Spotted a mistake? Edit the file on GitLab.

  • Site Repo
  • About GitLab
  • Terms
  • Privacy Statement
  • Contact

Page generated Wed, 14 May 2025 12:14:53 +0000.