CVE-2025-62595: Koa Vulnerable to Open Redirect via Trailing Double-Slash (//) in back Redirect Logic
### Summary: A bypass was discovered in the `Koa.js` framework affecting its back redirect functionality. In certain circumstances, an attacker can manipulate the Referer header to force a user’s browser to navigate to an external, potentially malicious website. This occurs because the implementation incorrectly treats some specially crafted URLs as safe relative paths. Exploiting this vulnerability could allow attackers to perform phishing, social engineering, or other redirect-based attacks on users of affected applications. This vulnerability affects the code referenced in GitHub Advisory GHSA-jgmv-j7ww-jx2x (which is tracked as CVE‑2025‑54420). ### Details: The patched code attempts to treat values that `startWith('/')` as safe relative paths and only perform origin checks for absolute URLs. However, protocol‑relative URLs (those beginning with //host) also start with '/' and therefore match the startsWith('/') branch. A protocol‑relative referrer such as `//evil.com` with trailing double-slash is treated by the implementation as a safe relative path, but browsers interpret Location: //evil.com as a redirect to https://evil.com (or http:// based on context). This discrepancy allows an attacker to supply Referer: //evil.com and trigger an external redirect - bypassing the intended same‑origin protection. ### Proof of concept (PoC): Affected line of code: https://github.com/koajs/koa/blob/master/lib/response.js#L326 The problematic logic looks like: <img width="567" height="509" alt="3" src="https://github.com/user-attachments/assets/33de440a-8945-4e5f-9e0a-2011a3999458" /> Request with a protocol‑relative Referer: curl -i -H "Referer: //haymiz.dev" http://127.0.0.1:3000/test <img width="2072" height="1005" alt="1" src="https://github.com/user-attachments/assets/55c48c79-559d-46aa-8b76-c1d2d3536c8b" /> Vulnerable response will contain: HTTP/1.1 302 Found Location: //haymiz.dev A browser receiving that Location header navigates to https://haymiz.dev (or http:// depending on context), resulting in an open redirect to an attacker‑controlled host: <img width="454" height="239" alt="2" src="https://github.com/user-attachments/assets/852ae81a-9f63-49c1-9ce5-72cd96bcea68" /> ### Recommendation / Patch: * Do not treat //host as a safe relative path. Explicitly exclude protocol‑relative values from any relative‑path branch. * Normalize the Referer by resolving it with a base (e.g., new URL(rawRef, ctx.href)), then compare resolved.origin (scheme+host+port) to ctx.origin (or ctx.host plus scheme/port) before allowing the redirect. ### Impact: An attacker who can cause a victim to visit a specially crafted link (or inject a request with a controlled Referer) can cause the victim to be redirected to an attacker‑controlled domain. This can be used for phishing, social engineering, or to bypass some protection rules that rely on same‑origin navigation.
Affected Software
Remediation
Event History
Frequently Asked Questions
What is the severity of CVE-2025-62595?
CVE-2025-62595 is classified as a medium severity vulnerability due to its potential for exploitation through the manipulation of the Referer header.
How do I fix CVE-2025-62595?
To fix CVE-2025-62595, upgrade your Koa.js framework to version 2.16.3 or 3.0.3 depending on your current version.
What versions of Koa.js are affected by CVE-2025-62595?
CVE-2025-62595 affects Koa.js versions 2.16.2 and below as well as 3.0.1 and below.
What type of attack does CVE-2025-62595 facilitate?
CVE-2025-62595 facilitates an open redirect attack allowing users to be redirected to malicious external websites.
Is CVE-2025-62595 specific to any deployment environments?
CVE-2025-62595 is primarily relevant in web applications using the Koa.js framework, regardless of specific deployment environments.