news 2026/4/1 7:10:08

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/3/25 16:19:03

Vue3-013 watch监视 ref 定义的数据

文章目录watch 作用watch 情况一&#xff1a;ref 定义的数据问题&#xff1a;为什么这里再次调用就停止这个函数了?箭头函数watch 情况二&#xff1a;ref 定义的对象数据watch 作用 watch 监视数据的变化&#xff0c;写法vue2与vue3中不同 watch 情况一&#xff1a;ref 定…

作者头像 李华
网站建设 2026/3/28 5:57:39

【dz-1010】基于单片机的药品生产车间环境监测

摘要 随着医药行业的严格规范&#xff0c;药品生产车间的环境参数对药品质量与生产安全至关重要。传统车间环境监测依赖人工巡检和手动记录&#xff0c;存在数据滞后、调控不及时、误差较大等问题&#xff0c;难以满足药品生产的高标准要求。 基于 STM32F103C8T6 单片机的药品…

作者头像 李华
网站建设 2026/3/24 18:42:19

合规领航:下一代数字资产交易所全栈架构设计“黄金法则”大公开

引言&#xff1a;数字资产交易所的“合规突围战”在数字货币狂潮席卷全球的当下&#xff0c;数字资产交易所作为这场金融变革的核心枢纽&#xff0c;正经历着前所未有的挑战与机遇。据统计&#xff0c;全球数字资产交易所数量已突破千家&#xff0c;日交易量峰值超千亿美元&…

作者头像 李华
网站建设 2026/3/24 1:29:13

C++ dll 设计接口时,能否用shared_ptr作为接口返回值?

C DLL 设计接口时&#xff0c;能否用 shared_ptr 作为接口返回值&#xff1f; 最简短的行业共识答案&#xff08;2025-2026&#xff09;&#xff1a; 强烈不推荐&#xff0c;绝大多数生产级项目都不这么做&#xff0c;几乎所有成熟的 C DLL 接口规范都明确禁止这样做。 为什…

作者头像 李华
网站建设 2026/3/24 7:04:25

没GPU怎么玩SAM 3?图像分割云端镜像2块钱搞定

没GPU怎么玩SAM 3&#xff1f;图像分割云端镜像2块钱搞定 你是不是也刷到过抖音上那种“一键抠图”的神操作&#xff1f;一张照片&#xff0c;点几下鼠标&#xff0c;人物、宠物、商品瞬间被精准分割出来&#xff0c;背景直接换掉——看起来像是PS高手花了几个小时的成果&…

作者头像 李华