Home

Description

PMD is an extensible multilanguage static code analyzer. Prior to version 7.22.0, PMD's `vbhtml` and `yahtml` report formats insert rule violation messages into HTML output without escaping. When PMD analyzes untrusted source code containing crafted string literals, the generated HTML report contains executable JavaScript that runs when opened in a browser. Practical impact is limited because `vbhtml` and `yahtml` are legacy formats rarely used in practice. The default `html` format is properly escaped and not affected. Version 7.22.0 contains a fix for the issue.

PUBLISHED Reserved 2026-02-26 | Published 2026-02-27 | Updated 2026-03-03 | Assigner GitHub_M




MEDIUM: 6.8CVSS:3.1/AV:N/AC:H/PR:N/UI:R/S:U/C:H/I:H/A:N

Problem types

CWE-79: Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')

Product status

< 7.22.0
affected

References

github.com/pmd/pmd/security/advisories/GHSA-8rr6-2qw5-pc7r

github.com/pmd/pmd/pull/6475

github.com/...ommit/c140c0e1de5853a08efb84c9f91dfeb015882442

cve.org (CVE-2026-28338)

nvd.nist.gov (CVE-2026-28338)

Download JSON