CVE-2026-46625
7.5 HIGHJavaScript Cookie is a JavaScript API for handling cookies, client-side
Published: 2026-06-10 · Last updated: 2026-06-10
Severity and scoring
- CVSS
- 7.5 HIGH
- Vector
- CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N
- CWE
- CWE-1321
Description
JavaScript Cookie is a JavaScript API for handling cookies, client-side. Prior to version 3.0.7, js-cookie's internal assign() helper copies properties with for...in + plain assignment. When the source object is produced by JSON.parse, the JSON object's "__proto__" member is an own enumerable property, so the for…in enumerates it and the target[key] = source[key] write triggers the Object.prototype.__proto__ setter on the fresh target ({}). The result is a per-instance prototype hijack: Object.prototype itself is untouched, but the merged attributes object now inherits attacker-controlled keys. Because the consuming set() function then enumerates the merged object with another for...in, every key the attacker placed on the polluted prototype lands in the resulting Set-Cookie string as an attribute pair. The attacker can set domain=, secure=, samesite=, expires=, and path= on cookies whose attributes the developer thought were locked down. This issue has been patched in version 3.0.7.
Source: NVD
References
Related CVEs
Same CWE
- CVE-2026-45302 — parse-nested-form-data is a tiny node module for parsing FormData by name into objects and arrays (8.2 HIGH)
- CVE-2026-46510 — form-data-objectizer converts FormData to object (8.2 HIGH)
- CVE-2026-46509 — deepobj provides get, set, delete deep objects in javascript (8.2 HIGH)
- CVE-2026-44483 — RVF (formerly Remix Validated Form) provides easy form validation and state management for React (8.2 HIGH)
- CVE-2026-44966 — Velocity.js is a JavaScript implementation of the Apache Velocity template engine (8.3 HIGH)