Home

Description

Tornado is a Python web framework and asynchronous networking library. Versions 6.5.2 and below use an inefficient algorithm when parsing parameters for HTTP header values, potentially causing a DoS. The _parseparam function in httputil.py is used to parse specific HTTP header values, such as those in multipart/form-data and repeatedly calls string.count() within a nested loop while processing quoted semicolons. If an attacker sends a request with a large number of maliciously crafted parameters in a Content-Disposition header, the server's CPU usage increases quadratically (O(n²)) during parsing. Due to Tornado's single event loop architecture, a single malicious request can cause the entire server to become unresponsive for an extended period. This issue is fixed in version 6.5.3.

PUBLISHED Reserved 2025-12-10 | Published 2025-12-12 | Updated 2025-12-18 | Assigner GitHub_M




HIGH: 7.5CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

Problem types

CWE-834: Excessive Iteration

CWE-400: Uncontrolled Resource Consumption

Product status

< 6.5.3
affected

References

github.com/...ornado/security/advisories/GHSA-jhmp-mqwm-3gq8

github.com/...ommit/771472cfdaeebc0d89a9cc46e249f8891a6b29cd

github.com/tornadoweb/tornado/releases/tag/v6.5.3

cve.org (CVE-2025-67726)

nvd.nist.gov (CVE-2025-67726)

Download JSON

Data based on CVE®. Copyright © 1999-2025, The MITRE Corporation. All rights reserved.