CVE-2026-21871
Last modified
CVE-2026-21871 is a medium-severity vulnerability rated 6.1/10 on the CVSS scale. NiceGUI is a Python-based UI framework. From versions 2.13.0 to 3.4.1, there is a XSS risk in NiceGUI when developers pass attacker-controlled strings into ui.navigate.history.push() or ui.navigate.history.replace(). EPSS estimates a 0.24% chance of exploitation in the next 30 days.
Description
NiceGUI is a Python-based UI framework. From versions 2.13.0 to 3.4.1, there is a XSS risk in NiceGUI when developers pass attacker-controlled strings into ui.navigate.history.push() or ui.navigate.history.replace(). These helpers are documented as History API wrappers for updating the browser URL without page reload. However, if the URL argument is embedded into generated JavaScript without proper escaping, a crafted payload can break out of the intended string context and execute arbitrary JavaScript in the victim’s browser. Applications that do not pass untrusted input into ui.navigate.history.push/replace are not affected. This issue has been patched in version 3.5.0.
Metrics
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
Weakness Enumeration
Affected Software
| Vendor | Product | Versions |
|---|---|---|
| Zauberzeug | Nicegui | >= 2.13.0, < 3.5.0 |
References
- https://github.com/zauberzeug/nicegui/security/advisories/GHSA-7grm-h62g-5m97Exploit, Vendor Advisory
Timeline
- Published
- Last Modified
- Status
- Analyzed
Frequently Asked Questions
What is CVE-2026-21871?
How severe is CVE-2026-21871?
How do I fix CVE-2026-21871?
Are you affected by CVE-2026-21871?
Run a free Strix scan to check your systems for this vulnerability.
Scan your code nowSource: NVD / NIST
