Apache Log4j 1 to Log4j 2 bridge: silent log event loss in Log4j1XmlLayout due to unescaped XML 1.0 forbidden characters
Moderate severity
GitHub Reviewed
Published
Apr 10, 2026
to the GitHub Advisory Database
•
Updated Apr 14, 2026
Package
Affected versions
>= 2.7, < 2.25.4
>= 3.0.0-beta1, <= 3.0.0-beta2
Patched versions
2.25.4
Description
Published by the National Vulnerability Database
Apr 10, 2026
Published to the GitHub Advisory Database
Apr 10, 2026
Reviewed
Apr 14, 2026
Last updated
Apr 14, 2026
The
Log4j1XmlLayoutfrom the Apache Log4j 1-to-Log4j 2 bridge fails to escape characters forbidden by the XML 1.0 standard, producing malformed XML output. Conforming XML parsers are required to reject documents containing such characters with a fatal error, which may cause downstream log processing systems to drop or fail to index affected records.Two groups of users are affected:
Log4j1XmlLayoutdirectly in a Log4j Core 2 configuration file.org.apache.log4j.xml.XMLLayoutspecified as the layout class.Users are advised to upgrade to Apache Log4j 1-to-Log4j 2 bridge version
2.25.4, which corrects this issue.Note
The Apache Log4j 1-to-Log4j 2 bridge is deprecated and will not be present in Log4j 3. Users are encouraged to consult the
Log4j 1 to Log4j 2 migration guide, and specifically the section on eliminating reliance on the bridge.
References