GHSA-w9hf-35q4-vcjw · Severity: medium · Ecosystem: go — nosurf vulnerable to CSRF due to non-functional same-origin request checks
nosurf is cross-site request forgery (CSRF) protection middleware for Go. A vulnerability in versions prior to 1.2.0 allows an attacker who controls content on the target site, or on a subdomain of the target site (either via XSS, or otherwise) to bypass CSRF checks and issue requests on user's behalf. Due to misuse of the Go `net/http` library, nosurf categorizes all incoming requests as plain-text HTTP requests, in which case the `Referer` header is not checked to have the same origin as the target webpage. If the attacker has control over HTML contents on either the target website (e.g. `example.com`), or on a website hosted on a subdomain of the target (e.g. `attacker.example.com`), they will also be able to manipulate cookies set for the target website. By acquiring the secret CSRF token from the cookie, or overriding the cookie with a new token known to the attacker, `attacker.example.com` is able to craft cross-site requests to `example.com`. A patch for the issue was released in nosurf 1.2.0. In lieu of upgrading to a patched version of nosurf, users may additionally use another HTTP middleware to ensure that a non-safe HTTP request is coming from the same origin (e.g. by requiring a `Sec-Fetch-Site: same-origin` header in the request).
Conclusion & alert: CVE-2025-46721 is rated Exploit Available (50/100): CVSS Medium severity, with low exploitation likelihood (EPSS 0.01%). Core evidence: 1 public exploit reference(s) are indexed (Exploit-DB). Mandatory action: Public exploits are available—assess exposure, apply mitigations, and prioritize patching.
Risk is dynamic; we continuously reassess and refresh what is shown on this page as upstream context changes.
| EDB-ID | Source | Kind | Published | Link |
|---|---|---|---|---|
| — | nvd_ref | exploit_tag | Exploit-DB ↗ |
EPSS lead: Daily EPSS estimates relative likelihood of exploitation; percentile ranks this CVE among scored vulnerabilities (higher = more severe relative rank).
| # | Date | Old EPSS score | New EPSS score | Delta (New - Old) |
|---|---|---|---|---|
| 1 | 2025-11-21 | 0.05% | 0.01% | -0.04% |
| 2 | 2025-11-18 | 0.02% | 0.05% | +0.03% |
| 3 | 2025-05-14 | — | 0.02% | — |
Full EPSS history (3 records total)
CVSS metrics for this CVE.
| Base score | Version | Severity | Vector | Exploitability | Impact | Score source |
|---|---|---|---|---|---|---|
| 6.0 | 4.0 | MEDIUM |
|
— | — | [email protected] |
| 6.1 | 3.1 | MEDIUM |
|
2.8 | 2.7 | [email protected] |
GHSA-w9hf-35q4-vcjw · Severity: medium · Ecosystem: go — nosurf vulnerable to CSRF due to non-functional same-origin request checks
| Vendor | Product | Version | Raw CPE |
|---|---|---|---|
| nosurf_project | nosurf | < 1.2.0 | cpe:2.3:a:nosurf_project:nosurf:*:*:*:*:*:go:*:* |
| URL | Tags |
|---|---|
| https://github.com/advisories/GHSA-rq77-p4h8-4crw | Not Applicable |
| https://github.com/justinas/nosurf-cve-2025-46721 | Exploit Third Party Advisory |
| https://github.com/justinas/nosurf/commit/ec9bb776d8e5ba9e906b6eb70428f4e7b009feee | Patch |
| https://github.com/justinas/nosurf/releases/tag/v1.2.0 | Release Notes |
| https://github.com/justinas/nosurf/security/advisories/GHSA-w9hf-35q4-vcjw | Vendor Advisory |