GHSA-x2f4-8wxf-w3vf: ZendFramework SQL injection due to execution of platform-specific SQL containing interpolations
The Zend\Db
component in Zend Framework 2 provides platform abstraction, which is used in particular for SQL abstraction. Two methods defined in the platform interface, quoteValue()
and quoteValueList()
, allow users to manually quote values for creating SQL statements; these are in turn consumed by aspects of the SQL abstraction platform, including Zend\Db\Sql\Sql::getSqlStringForSqlObject()
, and the getSqlString()
method provided in a number of classes in the Zend\Db\Sql namespace.
While these methods are primarily intended for debugging and logging purposes, developers can use them to produce SQL that is then passed to the driver to execute. Due to a flaw in how the quoteValue()
and quoteValueList()
methods were written, this can lead to potential SQL injection.
The offending code is located in any of the Zend\Db\Adapter\Platform*
objects, particularly the quoteValue() and quoteValueList()
methods. These methods did not take into account most of the possible escapable characters that would need to be escaped when attempting to create a quoted value for interpolation into a SQL string. Moreover, these methods did value quoting without extension level coordination which, when available, takes character-sets into account when quoting.
References
- framework.zend.com/security/advisory/ZF2013-03
- github.com/FriendsOfPHP/security-advisories/blob/master/zendframework/zendframework/ZF2013-03.yaml
- github.com/advisories/GHSA-x2f4-8wxf-w3vf
- github.com/zendframework/zendframework
- github.com/zendframework/zendframework/commit/0ef63e7db5fa30a79a58eb7c6466c6ab5c0618c5
- github.com/zendframework/zendframework/commit/546074660e6e10b9191bf0dc62b524d99f71a5cd
- github.com/zendframework/zendframework/commit/6d83777786b8e6171d82191ef917afd09fcb6601
- github.com/zendframework/zendframework/commit/870741d0c01a24ff23f9e209c8d393bd3a4115e3
- github.com/zendframework/zendframework/commit/95c88c236e80b475141d227bdf7866ca40287dd1
- github.com/zendframework/zendframework/commit/d1f259b9d6dbd7c3828360afcfdd3658f2163ea0
Detect and mitigate GHSA-x2f4-8wxf-w3vf 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 →