Jupyter Server is the backend for Jupyter web applications. In versions 2.17.0 and earlier, the Origin header validation uses Python's re.match() to check incoming origins against the allow_origin_pat configuration value. Because re.match() only anchors at the start of the string and does not require a full match, a pattern intended to match only a trusted domain (e.g., trusted.example.com) will also match any origin that begins with that domain followed by additional characters (e.g., trusted.example.com.evil.com). An attacker who controls such a domain can bypass the CORS origin restriction and make cross-origin requests to the Jupyter Server API from an untrusted site. This issue has been fixed in version 2.18.0.
References
Configurations
History
11 May 2026, 12:59
| Type | Values Removed | Values Added |
|---|---|---|
| References | () https://github.com/jupyter-server/jupyter_server/commit/057869a327c46730afede3eab0ca2d2e3e74acea - Patch | |
| References | () https://github.com/jupyter-server/jupyter_server/commit/49b34392feaa97735b3b777e3baf8f22f2a14ed8 - Patch | |
| References | () https://github.com/jupyter-server/jupyter_server/pull/603 - Issue Tracking | |
| References | () https://github.com/jupyter-server/jupyter_server/security/advisories/GHSA-24qx-w28j-9m6p - Patch, Vendor Advisory, Mitigation | |
| CVSS |
v2 : v3 : |
v2 : unknown
v3 : 7.3 |
| CPE | cpe:2.3:a:jupyter:jupyter_server:*:*:*:*:*:*:*:* | |
| First Time |
Jupyter
Jupyter jupyter Server |
05 May 2026, 22:16
| Type | Values Removed | Values Added |
|---|---|---|
| New CVE |
Information
Published : 2026-05-05 22:16
Updated : 2026-05-11 12:59
NVD link : CVE-2026-40110
Mitre link : CVE-2026-40110
CVE.ORG link : CVE-2026-40110
JSON object : View
Products Affected
jupyter
- jupyter_server
CWE
CWE-777
Regular Expression without Anchors
