CVE Vulnerabilities

CVE-2022-23305

Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection')

Published: Jan 18, 2022 | Modified: Feb 24, 2023
CVSS 3.x
9.8
CRITICAL
Source:
NVD
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
CVSS 2.x
6.8 MEDIUM
AV:N/AC:M/Au:N/C:P/I:P/A:P
RedHat/V2
RedHat/V3
8.8 IMPORTANT
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
Ubuntu
MEDIUM

By design, the JDBCAppender in Log4j 1.2.x accepts an SQL statement as a configuration parameter where the values to be inserted are converters from PatternLayout. The message converter, %m, is likely to always be included. This allows attackers to manipulate the SQL by entering crafted strings into input fields or headers of an application that are logged allowing unintended SQL queries to be executed. Note this issue only affects Log4j 1.x when specifically configured to use the JDBCAppender, which is not the default. Beginning in version 2.0-beta8, the JDBCAppender was re-introduced with proper support for parameterized SQL queries and further customization over the columns written to in logs. Apache Log4j 1.2 reached end of life in August 2015. Users should upgrade to Log4j 2 as it addresses numerous other issues from the previous versions.

Weakness

The product constructs all or part of an SQL command using externally-influenced input from an upstream component, but it does not neutralize or incorrectly neutralizes special elements that could modify the intended SQL command when it is sent to a downstream component.

Affected Software

Name Vendor Start Version End Version
Log4j Apache 1.2 (including) 1.2.17 (including)
EAP 6.4.24 release RedHat *
EAP 6.4 log4j async RedHat log4j *
EAP 7.4.4 release RedHat log4j *
EAP 7.4 log4j async RedHat log4j *
Red Hat AMQ Streams 1.6.7 RedHat *
Red Hat AMQ Streams 2.0.1 RedHat log4j *
Red Hat Data Grid 7.3.9 RedHat log4j *
Red Hat Enterprise Linux 6 Extended Lifecycle Support RedHat log4j-0:1.2.14-6.6.el6_10 *
Red Hat Enterprise Linux 7 RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 7.3 Advanced Update Support RedHat log4j-0:1.2.17-17.el7_3 *
Red Hat Enterprise Linux 7.4 Advanced Update Support RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 7.6 Advanced Update Support RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 7.6 Telco Extended Update Support RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 7.6 Update Services for SAP Solutions RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 7.7 Advanced Update Support RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 7.7 Telco Extended Update Support RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 7.7 Update Services for SAP Solutions RedHat log4j-0:1.2.17-18.el7_4 *
Red Hat Enterprise Linux 8 RedHat parfait:0.5-8050020220124063900.6b489b78 *
Red Hat Enterprise Linux 8.1 Update Services for SAP Solutions RedHat parfait:0.5-8010020220124232535.d5701770 *
Red Hat Enterprise Linux 8.2 Extended Update Support RedHat parfait:0.5-8020020220124231008.1c5d4e8a *
Red Hat Enterprise Linux 8.4 Extended Update Support RedHat parfait:0.5-8040020220124230039.d304d9ed *
Red Hat Fuse 7.10.1 RedHat log4j *
Red Hat Fuse/AMQ 6.3.20 RedHat log4j *
Red Hat Fuse/AMQ 6.3.20 RedHat log4j *
Red Hat JBoss Data Virtualization 6.4.8.SP1 RedHat log4j *
Red Hat JBoss Data Virtualization 6.4.8.SP2 RedHat log4j *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat log4j-eap6-0:1.2.17-3.redhat_00008.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat log4j-jboss-logmanager-0:1.1.4-3.Final_redhat_00002.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-appclient-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-appclient-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-bundles-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-cli-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-client-all-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-clustering-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-cmp-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-configadmin-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-connector-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-controller-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-controller-client-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-core-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-core-security-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-deployment-repository-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-deployment-scanner-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-domain-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-domain-http-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-domain-management-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-ee-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-ee-deployment-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-ejb3-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-embedded-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-host-controller-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jacorb-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-javadocs-0:7.5.24-1.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jaxr-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jaxrs-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jdr-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jmx-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jpa-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jsf-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-jsr77-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-logging-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-mail-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-management-client-content-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-messaging-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-modcluster-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-modules-eap-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-naming-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-network-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-osgi-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-osgi-configadmin-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-osgi-service-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-picketlink-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-platform-mbean-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-pojo-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-process-controller-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-product-eap-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-protocol-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-remoting-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-sar-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-security-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-server-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-standalone-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-system-jmx-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-threads-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-transactions-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-version-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-web-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-webservices-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossas-welcome-content-eap-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-weld-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jboss-as-xts-0:7.5.24-2.Final_redhat_00001.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossts-1:4.17.45-2.Final_redhat_2.1.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 6 RedHat jbossweb-0:7.5.32-2.Final_redhat_1.2.ep6.el6 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat log4j-eap6-0:1.2.17-3.redhat_00008.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat log4j-jboss-logmanager-0:1.1.4-3.Final_redhat_00002.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-appclient-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-appclient-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-bundles-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-cli-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-client-all-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-clustering-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-cmp-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-configadmin-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-connector-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-controller-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-controller-client-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-core-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-core-security-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-deployment-repository-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-deployment-scanner-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-domain-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-domain-http-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-domain-management-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-ee-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-ee-deployment-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-ejb3-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-embedded-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-host-controller-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jacorb-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-javadocs-0:7.5.24-1.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jaxr-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jaxrs-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jdr-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jmx-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jpa-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jsf-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-jsr77-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-logging-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-mail-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-management-client-content-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-messaging-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-modcluster-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-modules-eap-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-naming-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-network-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-osgi-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-osgi-configadmin-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-osgi-service-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-picketlink-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-platform-mbean-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-pojo-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-process-controller-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-product-eap-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-protocol-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-remoting-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-sar-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-security-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-server-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-standalone-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-system-jmx-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-threads-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-transactions-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-version-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-web-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-webservices-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossas-welcome-content-eap-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-weld-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jboss-as-xts-0:7.5.24-2.Final_redhat_00001.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossts-1:4.17.45-2.Final_redhat_2.1.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 6.4 for RHEL 7 RedHat jbossweb-0:7.5.32-2.Final_redhat_1.2.ep6.el7 *
Red Hat JBoss Enterprise Application Platform 7.1 EUS for RHEL 7 RedHat eap7-log4j-jboss-logmanager-0:1.2.2-1.Final_redhat_00002.1.ep7.el7 *
Red Hat JBoss Enterprise Application Platform 7.4 for RHEL 8 RedHat eap7-log4j-jboss-logmanager-0:1.2.2-1.Final_redhat_00002.1.el8eap *
Red Hat JBoss Enterprise Application Platform 7.4 for RHEL 8 RedHat eap7-log4j-0:2.17.1-1.redhat_00001.1.el8eap *
Red Hat JBoss Enterprise Application Platform 7.4 on RHEL 7 RedHat eap7-log4j-jboss-logmanager-0:1.2.2-1.Final_redhat_00002.1.el7eap *
Red Hat JBoss Enterprise Application Platform 7.4 on RHEL 7 RedHat eap7-log4j-0:2.17.1-1.redhat_00001.1.el7eap *
Red Hat JBoss Web Server 3.1 RedHat log4j-eap6 *
Red Hat JBoss Web Server 3 for RHEL 7 RedHat log4j-eap6-0:1.2.17-3.redhat_00008.1.ep6.el7 *
Red Hat JBoss Web Server 3 for RHEL 7 RedHat tomcat7-0:7.0.70-46.ep7.el7 *
Red Hat JBoss Web Server 3 for RHEL 7 RedHat tomcat8-0:8.0.36-49.ep7.el7 *
Red Hat JBoss Web Server 3 for RHEL 7 RedHat tomcat-native-0:1.2.23-26.redhat_26.ep7.el7 *
Red Hat Single Sign-On 7.4.10 RedHat log4j *
Red Hat Single Sign-On 7.5 for RHEL 7 RedHat rh-sso7-keycloak-0:15.0.4-1.redhat_00003.1.el7sso *
Red Hat Single Sign-On 7.5 for RHEL 8 RedHat rh-sso7-keycloak-0:15.0.4-1.redhat_00003.1.el8sso *
Red Hat Software Collections for Red Hat Enterprise Linux 7 RedHat rh-maven36-log4j12-0:1.2.17-23.4.el7 *
Red Hat Virtualization Engine 4.4 RedHat org.ovirt.engine-root-0:4.4.10.6-1 *
Red Hat Virtualization Engine 4.4 RedHat snmp4j-0:3.6.4-0.1.el8ev *
RHEL-8 based Middleware Containers RedHat rh-sso-7/sso74-openshift-rhel8:7.4-45 *
RHEL-8 based Middleware Containers RedHat rh-sso-7/sso74-openj9-openshift-rhel8:7.4-60 *
RHEL-8 based Middleware Containers RedHat rh-sso-7/sso75-openshift-rhel8:7.5-17 *
RHEL-8 based Middleware Containers RedHat rh-sso-7/sso7-rhel8-operator-bundle:7.5.1-9 *
RHSSO 7.5.1 RedHat log4j *
Apache-log4j1.2 Ubuntu bionic *
Apache-log4j1.2 Ubuntu esm-apps/xenial *
Apache-log4j1.2 Ubuntu focal *
Apache-log4j1.2 Ubuntu impish *
Apache-log4j1.2 Ubuntu lunar *
Apache-log4j1.2 Ubuntu mantic *
Apache-log4j1.2 Ubuntu trusty *
Apache-log4j1.2 Ubuntu xenial *

Extended Description

Without sufficient removal or quoting of SQL syntax in user-controllable inputs, the generated SQL query can cause those inputs to be interpreted as SQL instead of ordinary user data. This can be used to alter query logic to bypass security checks, or to insert additional statements that modify the back-end database, possibly including execution of system commands. SQL injection has become a common issue with database-driven web sites. The flaw is easily detected, and easily exploited, and as such, any site or product package with even a minimal user base is likely to be subject to an attempted attack of this kind. This flaw depends on the fact that SQL makes no real distinction between the control and data planes.

Potential Mitigations

  • Use a vetted library or framework that does not allow this weakness to occur or provides constructs that make this weakness easier to avoid.
  • For example, consider using persistence layers such as Hibernate or Enterprise Java Beans, which can provide significant protection against SQL injection if used properly.
  • If available, use structured mechanisms that automatically enforce the separation between data and code. These mechanisms may be able to provide the relevant quoting, encoding, and validation automatically, instead of relying on the developer to provide this capability at every point where output is generated.
  • Process SQL queries using prepared statements, parameterized queries, or stored procedures. These features should accept parameters or variables and support strong typing. Do not dynamically construct and execute query strings within these features using “exec” or similar functionality, since this may re-introduce the possibility of SQL injection. [REF-867]
  • Run your code using the lowest privileges that are required to accomplish the necessary tasks [REF-76]. If possible, create isolated accounts with limited privileges that are only used for a single task. That way, a successful attack will not immediately give the attacker access to the rest of the software or its environment. For example, database applications rarely need to run as the database administrator, especially in day-to-day operations.
  • Specifically, follow the principle of least privilege when creating user accounts to a SQL database. The database users should only have the minimum privileges necessary to use their account. If the requirements of the system indicate that a user can read and modify their own data, then limit their privileges so they cannot read/write others’ data. Use the strictest permissions possible on all database objects, such as execute-only for stored procedures.
  • While it is risky to use dynamically-generated query strings, code, or commands that mix control and data together, sometimes it may be unavoidable. Properly quote arguments and escape any special characters within those arguments. The most conservative approach is to escape or filter all characters that do not pass an extremely strict allowlist (such as everything that is not alphanumeric or white space). If some special characters are still needed, such as white space, wrap each argument in quotes after the escaping/filtering step. Be careful of argument injection (CWE-88).
  • Instead of building a new implementation, such features may be available in the database or programming language. For example, the Oracle DBMS_ASSERT package can check or enforce that parameters have certain properties that make them less vulnerable to SQL injection. For MySQL, the mysql_real_escape_string() API function is available in both C and PHP.
  • Assume all input is malicious. Use an “accept known good” input validation strategy, i.e., use a list of acceptable inputs that strictly conform to specifications. Reject any input that does not strictly conform to specifications, or transform it into something that does.
  • When performing input validation, consider all potentially relevant properties, including length, type of input, the full range of acceptable values, missing or extra inputs, syntax, consistency across related fields, and conformance to business rules. As an example of business rule logic, “boat” may be syntactically valid because it only contains alphanumeric characters, but it is not valid if the input is only expected to contain colors such as “red” or “blue.”
  • Do not rely exclusively on looking for malicious or malformed inputs. This is likely to miss at least one undesirable input, especially if the code’s environment changes. This can give attackers enough room to bypass the intended validation. However, denylists can be useful for detecting potential attacks or determining which inputs are so malformed that they should be rejected outright.
  • When constructing SQL query strings, use stringent allowlists that limit the character set based on the expected value of the parameter in the request. This will indirectly limit the scope of an attack, but this technique is less important than proper output encoding and escaping.
  • Note that proper output encoding, escaping, and quoting is the most effective solution for preventing SQL injection, although input validation may provide some defense-in-depth. This is because it effectively limits what will appear in output. Input validation will not always prevent SQL injection, especially if you are required to support free-form text fields that could contain arbitrary characters. For example, the name “O’Reilly” would likely pass the validation step, since it is a common last name in the English language. However, it cannot be directly inserted into the database because it contains the “’” apostrophe character, which would need to be escaped or otherwise handled. In this case, stripping the apostrophe might reduce the risk of SQL injection, but it would produce incorrect behavior because the wrong name would be recorded.
  • When feasible, it may be safest to disallow meta-characters entirely, instead of escaping them. This will provide some defense in depth. After the data is entered into the database, later processes may neglect to escape meta-characters before use, and you may not have control over those processes.
  • Ensure that error messages only contain minimal details that are useful to the intended audience and no one else. The messages need to strike the balance between being too cryptic (which can confuse users) or being too detailed (which may reveal more than intended). The messages should not reveal the methods that were used to determine the error. Attackers can use detailed information to refine or optimize their original attack, thereby increasing their chances of success.
  • If errors must be captured in some detail, record them in log messages, but consider what could occur if the log messages can be viewed by attackers. Highly sensitive information such as passwords should never be saved to log files.
  • Avoid inconsistent messaging that might accidentally tip off an attacker about internal state, such as whether a user account exists or not.
  • In the context of SQL Injection, error messages revealing the structure of a SQL query can help attackers tailor successful attack strings.

References