CVE-2016-10007: Vulnerability Analysis & Exploit Details

Status: Modified - Last modified: 21-11-2024 Published: 19-02-2018

CVE-2016-10007
Vulnerability Scoring

7.2
/10

Attack Complexity Details

  • Attack Complexity: Low Impact
  • Attack Vector: NETWORK
  • Privileges Required: HIGH IMPACT
  • Scope: UNCHANGED
  • User Interaction: NONE

CIA Impact Definition

  • Confidentiality: HIGH IMPACT
  • Integrity: HIGH IMPACT
  • Availability: HIGH IMPACT

CVE-2016-10007 Vulnerability Summary

SQL injection vulnerability in the "Marketing > Forms" screen in dotCMS before 3.7.2 and 4.x before 4.1.1 allows remote authenticated administrators to execute arbitrary SQL commands via the _EXT_FORM_HANDLER_orderBy parameter.

Need help fixing CVEs? Check out our Step-by-Step Guide on How to Fix CVEs.

Access Complexity Graph for CVE-2016-10007

Impact Analysis for CVE-2016-10007

CVE-2016-10007: Detailed Information and External References

EPSS

0.00209

EPSS %

0.58804

References

0.00209

CWE

CWE-89

CAPEC

0.00209

  • Command Line Execution through SQL Injection: An attacker uses standard SQL injection methods to inject data into the command line for execution. This could be done directly through misuse of directives such as MSSQL_xp_cmdshell or indirectly through injection of data into the database that would be interpreted as shell commands. Sometime later, an unscrupulous backend application (or could be part of the functionality of the same application) fetches the injected data stored in the database and uses this data as command line arguments without performing proper validation. The malicious data escapes that data plane by spawning new commands to be executed on the host.
  • Object Relational Mapping Injection: An attacker leverages a weakness present in the database access layer code generated with an Object Relational Mapping (ORM) tool or a weakness in the way that a developer used a persistence framework to inject their own SQL commands to be executed against the underlying database. The attack here is similar to plain SQL injection, except that the application does not use JDBC to directly talk to the database, but instead it uses a data access layer generated by an ORM tool or framework (e.g. Hibernate). While most of the time code generated by an ORM tool contains safe access methods that are immune to SQL injection, sometimes either due to some weakness in the generated code or due to the fact that the developer failed to use the generated access methods properly, SQL injection is still possible.
  • SQL Injection through SOAP Parameter Tampering: An attacker modifies the parameters of the SOAP message that is sent from the service consumer to the service provider to initiate a SQL injection attack. On the service provider side, the SOAP message is parsed and parameters are not properly validated before being used to access a database in a way that does not use parameter binding, thus enabling the attacker to control the structure of the executed SQL query. This pattern describes a SQL injection attack with the delivery mechanism being a SOAP message.
  • Expanding Control over the Operating System from the Database: An attacker is able to leverage access gained to the database to read / write data to the file system, compromise the operating system, create a tunnel for accessing the host machine, and use this access to potentially attack other machines on the same network as the database machine. Traditionally SQL injections attacks are viewed as a way to gain unauthorized read access to the data stored in the database, modify the data in the database, delete the data, etc. However, almost every data base management system (DBMS) system includes facilities that if compromised allow an attacker complete access to the file system, operating system, and full access to the host running the database. The attacker can then use this privileged access to launch subsequent attacks. These facilities include dropping into a command shell, creating user defined functions that can call system level libraries present on the host machine, stored procedures, etc.
  • SQL Injection: This attack exploits target software that constructs SQL statements based on user input. An attacker crafts input strings so that when the target software constructs SQL statements based on the input, the resulting SQL statement performs actions other than those the application intended. SQL Injection results from failure of the application to appropriately validate input.
  • Blind SQL Injection: Blind SQL Injection results from an insufficient mitigation for SQL Injection. Although suppressing database error messages are considered best practice, the suppression alone is not sufficient to prevent SQL Injection. Blind SQL Injection is a form of SQL Injection that overcomes the lack of error messages. Without the error messages that facilitate SQL Injection, the adversary constructs input strings that probe the target through simple Boolean SQL expressions. The adversary can determine if the syntax and structure of the injection was successful based on whether the query was executed or not. Applied iteratively, the adversary determines how and where the target is vulnerable to SQL Injection.

Vulnerable Configurations

  • cpe:2.3:a:dotcms:dotcms:1.9:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:1.9:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:1.9.2.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:1.9.2.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:1.9.5.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:1.9.5.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.0:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.0:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.0.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.0.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.1.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.1.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.2:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.2:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.2.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.2.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.3:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.3:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.3.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.3.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.3.2:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.3.2:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.5:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.5:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.5.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.5.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.5.2:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.5.2:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.5.3:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.5.3:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:2.5.4:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:2.5.4:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.0:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.0:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.0.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.0.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.2:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.2:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.2.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.2.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.2.2:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.2.2:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.2.3:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.2.3:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.2.4:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.2.4:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.3:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.3:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.3.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.3.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.3.2:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.3.2:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.5:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.5:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.5.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.5.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.6.0:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.6.0:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.6.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.6.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.6.2:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.6.2:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.7.0:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.7.0:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:3.7.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:3.7.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:4.0.0:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:4.0.0:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:4.0.1:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:4.0.1:*:*:*:*:*:*:*
  • cpe:2.3:a:dotcms:dotcms:4.1.0:*:*:*:*:*:*:*
    cpe:2.3:a:dotcms:dotcms:4.1.0:*:*:*:*:*:*:*

CVSS3 Source

nvd@nist.gov

CVSS3 Type

Primary

CVSS3 Vector

CVSS:3.0/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H

Protect Your Infrastructure: Combat Critical CVE Threats

Stay updated with real-time CVE vulnerabilities and take action to secure your systems. Enhance your cybersecurity posture with the latest threat intelligence and mitigation techniques. Develop the skills necessary to defend against CVEs and secure critical infrastructures. Join the top cybersecurity professionals safeguarding today's infrastructures.

Recently Published CVEs