Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection')
CVE-2025-59681
Summary
An issue was discovered in Django versions 4.2.x prior to 4.2.25, 5.0.x prior to 5.1.13, 5.2.x prior to 5.2.7, and 6.0a1. 'QuerySet.annotate()', 'QuerySet.alias()', 'QuerySet.aggregate()', and 'QuerySet.extra()' are subject to SQL injection in column aliases, when using a suitably crafted dictionary, with dictionary expansion, as the **kwargs passed to these methods (on MySQL and MariaDB).
- LOW
- NETWORK
- HIGH
- UNCHANGED
- NONE
- NONE
- HIGH
- HIGH
CWE-89 - SQL Injection
Structured Query Language (SQL) injection attacks are one of the most common types of vulnerabilities. They exploit weaknesses in vulnerable applications to gain unauthorized access to backend databases. This often occurs when an attacker enters unexpected SQL syntax in an input field. The resulting SQL statement behaves in the background in an unintended manner, which allows the possibility of unauthorized data retrieval, data modification, execution of database administration operations, and execution of commands on the operating system.
References
Advisory Timeline
- Published