CVE-2026-21871

MEDIUM

NiceGUI 2.13.0-3.4.1 - Cross-Site Scripting via History API Navigation Helpers

Title source: llm
STIX 2.1

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.

References (2)

Core 2
Core References

Scores

CVSS v3 6.1
EPSS 0.0002
EPSS Percentile 6.0%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N

CISA SSVC

Vulnrichment
Exploitation poc
Automatable no
Technical Impact partial

Details

CWE
CWE-79
Status published
Products (2)
pypi/nicegui 2.13.0 - 3.5.0PyPI
zauberzeug/nicegui 2.13.0 - 3.5.0
Published Jan 08, 2026
Tracked Since Feb 18, 2026