news 2026/2/7 9:59:25

JavaScript 的 `document.cookie`:99% 开发者都踩过的致命陷阱,你中招了吗?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JavaScript 的 `document.cookie`:99% 开发者都踩过的致命陷阱,你中招了吗?

你有没有过这种崩溃时刻?用户登录后,一刷新页面就自动登出;购物车内容莫名消失;甚至在测试环境好好的功能,一上线就“人间蒸发”……别急,问题很可能藏在document.cookie里——这个被无数开发者当作“万能钥匙”的属性,实则是个披着羊皮的狼!今天,我作为混迹前端圈十年的老炮,带你撕开它的伪装,从原理到血泪教训,手把手教你避开这些“隐形炸弹”。


一、document.cookie:你以为的“简单字符串”,其实是座数据矿场

别被名字骗了!document.cookie不是普通字符串,而是一个可读可写的字符串属性,它存储了当前域名下所有 cookie 的键值对(用;分隔)。比如:

// 假设已设置过 cookieconsole.log(document.cookie);// 输出: "username=John; theme=dark; session=abc123"

但真相是:它只负责“传递”数据,真正的操作逻辑藏在浏览器底层

  • 读取:直接读取字符串,但需手动解析(见下文)。
  • 写入:赋值时,浏览器会自动添加 cookie(如document.cookie = "token=xyz")。
  • ⚠️关键陷阱:如果你写document.cookie = "name=John"不会自动覆盖旧值!必须指定pathdomain,否则可能写到错误路径。

💡为什么开发者总栽跟头?因为它像“黑盒”:你只看到结果,却忽略了浏览器的隐式规则(比如默认path=/)。


二、Cookie 属性:90% 的人只用过namevalue,其他全是隐藏技能!

Cookie 的威力,全靠这些“魔法属性”加持。下面用真实场景拆解:

属性作用示例为什么重要?
expires设置过期时间(GMT 格式)expires=Wed, 31 Dec 2025 23:59:59 GMT不设就默认会话结束失效!常被忽略导致“登录状态消失”。
path指定 cookie 作用的路径path=/admin不设默认为当前路径!若路径不对,读不到值。
domain指定域名(跨子域时需设置)domain=example.comwww.example.com时,domain=example.com才能共享。
secure仅 HTTPS 下传输secure必须加!否则 HTTP 网站会泄露敏感数据
httpOnlyJavaScript 无法访问(防 XSS)httpOnly核心安全属性!但只能由服务器设置,JS 无法控制!

💡血泪案例:某电商项目因漏写path=/,用户在/checkout页面能读到cartcookie,但/product页读不到——排查一周才发现是路径问题!


三、实操指南:3 行代码搞定 cookie,但 90% 的人写错了!

✅ 正确操作(附安全建议):
// 1. 设置 cookie(安全版:带 expires、secure、path)functionsetCookie(name,value,days){constdate=newDate();date.setTime(date.getTime()+(days*24*60*60*1000));document.cookie=`${name}=${encodeURIComponent(value)}; expires=${date.toUTCString()}; path=/; secure`;}// 2. 读取 cookie(解析字符串)functiongetCookie(name){constnameEQ=`${name}=`;constcookies=document.cookie.split(';');for(leti=0;i<cookies.length;i++){letcookie=cookies[i].trim();if(cookie.indexOf(nameEQ)===0)returndecodeURIComponent(cookie.substring(nameEQ.length));}returnnull;}// 3. 删除 cookie(关键!设为过去时间)functiondeleteCookie(name){document.cookie=`${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/`;}

⚠️致命错误

  • 未用encodeURIComponent→ 用户名含&会破坏 cookie 结构(如name=John&age=30→ 变成两个 key)。
  • 忘记secure→ 开发时用http://测试,上线后 HTTPS 时 cookie 无法发送。

四、安全雷区:你的 cookie 可能正在被黑客“偷家”!

document.cookie是 XSS 攻击的头号目标!攻击者通过注入脚本,直接读取 cookie(如document.cookie被窃取)。

  • 防御铁律
    1. 关键 cookie(如 token)必须设httpOnly(服务器设置,JS 无法操作)。
    2. 所有 cookie 设secure(强制 HTTPS 传输)。
    3. 避免存储敏感数据:用sessionStorage或后端会话管理替代。

💡真实教训:某支付平台因未设httpOnly,黑客通过 XSS 获取用户 token,导致 5000+ 账户被盗!


五、进阶方向:别再手动操作 cookie,用库才是真·高手!

手动写 cookie 解析太容易出错,推荐用js-cookie(轻量级、安全封装):

// 用 js-cookie 代替原生操作Cookies.set('token','xyz',{expires:7,secure:true,path:'/'});Cookies.get('token');// 安全解析,自动处理编码Cookies.remove('token');
  • 为什么用它?它自动处理encodeURIComponentpath默认值,且避免 XSS 风险。
  • 进阶学习:深入研究Web 安全(OWASP Top 10)和HTTP 传输层安全(HSTS)。

结语:cookie 不是“玩具”,而是“责任”

document.cookie本质是浏览器的“数据存储通道”,但它的强大恰恰源于其脆弱性——一个参数疏忽,就可能让整个应用陷入危机。记住:安全不是“加个 flag”,而是刻进开发骨子里的习惯

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 17:45:30

【dz-1008】基于单片机的环境监测系统设计

摘要 随着人们对生活环境质量关注度的不断提升&#xff0c;对环境参数的精准监测与及时预警变得尤为重要。传统的环境监测方式多依赖人工采样和实验室分析&#xff0c;不仅耗时费力、响应滞后&#xff0c;还存在数据获取不及时、监测范围有限等问题&#xff0c;难以满足实时、…

作者头像 李华
网站建设 2026/2/6 21:28:05

【dz-1012】小型无士栽培自动控制系统设计与实现

摘要 在无土栽培领域&#xff0c;环境参数与营养液状态的精准调控对作物生长质量与产量起着决定性作用。传统无土栽培管理多依赖人工巡检和经验调节&#xff0c;存在参数控制滞后、营养液配比失衡、资源浪费等问题&#xff0c;难以满足精细化种植的严苛需求。 基于 STM32F103…

作者头像 李华
网站建设 2026/1/30 19:58:16

绿色工厂与上市公司匹配数据(2017-2023)

1729顶刊收割机&#xff01;绿色工厂与上市公司匹配数据&#xff08;2017-2023&#xff09;数据简介2016年工业和信息化部&#xff08;以下简称工信部&#xff09;启动了第一批绿色制造体系示范建设项目&#xff0c;该项目涵盖绿色工厂、绿色产品、绿色园区、绿色供应链等多方面…

作者头像 李华
网站建设 2026/2/6 17:49:25

3 大核心 + 全产业链!小理家按摩机器人,选对的关键在这

随着亚健康问题日益普遍&#xff0c;智能康养需求持续攀升&#xff0c;按摩机器人作为替代传统人工按摩的重要品类&#xff0c;市场规模实现快速增长。面对市面上众多品牌&#xff0c;消费者与投资者该如何选择&#xff1f;从技术实力、商业模式、服务体系等核心维度来看&#…

作者头像 李华
网站建设 2026/1/30 15:30:04

gpt-oss-20b-WEBUI文本生成实战:云端3步快速体验

gpt-oss-20b-WEBUI文本生成实战&#xff1a;云端3步快速体验 你是不是也经常刷到同行用AI写出爆款文章&#xff0c;标题吸睛、内容流畅、观点犀利&#xff0c;仿佛背后有个专业编辑团队&#xff1f;而你自己还在熬夜改稿、绞尽脑汁想选题&#xff0c;效率低还不出效果。更头疼…

作者头像 李华
网站建设 2026/2/7 5:09:25

AI产品经理:未来5年最值得All In的职业,小白也能上手

文章指出AI产品经理是未来5年最有前景的职业&#xff0c;大多数人想抓住AI机会但处于观望、迷茫或跑偏三种状态。AI产品经理分为工具型、应用型和专业型三个层次&#xff0c;对多数人而言&#xff0c;成为应用型AI产品经理是最佳选择。文章提出三步学习法&#xff1a;夯实产品基…

作者头像 李华