GHSA-jpcq-cgw6-v4j6
MEDIUMPotential XSS vulnerability in jQuery
EPSS Exploitation Probability
EPSS (Exploit Prediction Scoring System) is a daily probability model maintained by FIRST.org. It estimates the likelihood a CVE will be exploited in production environments within the next 30 days, derived from real-world threat intelligence signals.
Blast Radius
org.webjars.npm:jquery📦jquery.NETjQuery🐘components/jquery💎jquery-railsReal-time download stats are indexed for npm and PyPI packages. This vulnerability affects Maven, npm, NuGet packages — download data is not available via public APIs for these ecosystems.
Description
Impact
Passing HTML containing <option> elements from untrusted sources - even after sanitizing them - to one of jQuery's DOM manipulation methods (i.e. .html(), .append(), and others) may execute untrusted code.
Patches
This problem is patched in jQuery 3.5.0.
Workarounds
To workaround this issue without upgrading, use DOMPurify with its SAFE_FOR_JQUERY option to sanitize the HTML string before passing it to a jQuery method.
References
https://blog.jquery.com/2020/04/10/jquery-3-5-0-released/
For more information
If you have any questions or comments about this advisory, search for a relevant issue in the jQuery repo. If you don't find an answer, open a new issue.
Affected Packages
| Ecosystem | Package | Vulnerable range | Fix |
|---|---|---|---|
| ☕Maven | org.webjars.npm:jquery | ≥ 1.0.3&&< 3.5.0 | 3.5.0 |
| 📦npm | jquery | ≥ 1.0.3&&< 3.5.0 | 3.5.0 |
| .NETNuGet | jQuery | ≥ 1.0.3&&< 3.5.0 | 3.5.0 |
| 🐘Packagist | components/jquery | ≥ 1.0.3&&< 3.5.0 | 3.5.0 |
| 💎RubyGems | jquery-rails | all versions | 4.4.0 |
Research use only. For defensive security, authorized penetration testing, and academic research only. Never execute exploit code against systems without explicit written authorization.
jQuery 1.0.3 - Cross-Site Scripting (XSS)
by Central InfoSec · Apr 14, 2021
Frequently Asked Questions
Is GHSA-jpcq-cgw6-v4j6 in your stack?
O3 detects GHSA-jpcq-cgw6-v4j6 across Maven, npm, NuGet dependencies and uses function-level reachability to confirm whether the vulnerable code path is actually reachable — not just present. No false positives.