news 2026/4/23 12:58:17

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/4/10 7:47:51

Springboot小树立社工服务中心管理信息系统9mpe3(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序文件列表项目功能&#xff1a;案主,社工,服务信息,服务类型,招聘信息,招聘类型,服务订单,分配信息,服务内容,评价打分,退单信息,工资信息,活动支出,外界捐助,考勤信息开题报告内容一、研究背景与意义随着社会治理体系的不断完善&#xff0c;公众对社区服务的需求呈现多…

作者头像 李华
网站建设 2026/4/10 8:23:24

【dz-1015】基于STM32单片机智能鱼缸

摘要 在观赏鱼养殖领域&#xff0c;水质状态、水温稳定性及饲喂合理性对鱼类生存质量与健康状况起着决定性作用。传统鱼缸管理多依赖人工换水、经验控温及定时投喂&#xff0c;存在水质恶化预警滞后、水温波动大、饲喂不规律等问题&#xff0c;难以满足精细化养殖的严苛需求。…

作者头像 李华
网站建设 2026/4/17 22:11:21

SenseVoice多语言识别实战:3步搞定50种语言测试

SenseVoice多语言识别实战&#xff1a;3步搞定50种语言测试 你是不是也遇到过这样的问题&#xff1f;作为跨境电商的小老板&#xff0c;每天收到大量来自不同国家客户的语音留言、客服录音、产品反馈&#xff0c;但语言五花八门——英语、西班牙语、日语、阿拉伯语……靠人工翻…

作者头像 李华
网站建设 2026/4/23 12:51:21

Flux.1-dev创意变现:非商用的合法途径

Flux.1-dev创意变现&#xff1a;非商用的合法途径 你是不是也听说过 Flux.1-dev 这个强大的文生图AI模型&#xff1f;它生成的图像质量极高&#xff0c;细节丰富&#xff0c;人物面部、毛发、衣物纹理都清晰逼真&#xff0c;甚至能精准还原复杂提示词。更吸引人的是——它是开…

作者头像 李华
网站建设 2026/4/23 11:00:18

Vllm-v0.11.0中文评测:租用GPU自己测,比看报告直观

Vllm-v0.11.0中文评测&#xff1a;租用GPU自己测&#xff0c;比看报告直观 你是不是也遇到过这种情况&#xff1a;看到某个AI模型宣传“中文理解能力超强”“响应速度快如闪电”&#xff0c;但翻遍评测文章却发现数据来源模糊、测试方式不透明&#xff0c;根本没法判断真实表现…

作者头像 李华