0

0

JavaScript如何操作Cookies_有哪些安全考量【教程】

夢幻星辰

夢幻星辰

发布时间:2026-01-21 16:00:02

|

486人浏览过

|

来源于php中文网

原创

document.cookie只能读写非httponly cookie,读取返回分号分隔字符串需手动解析,写入需拼接完整键值及属性(如expires、path、secure、samesite),删除须设过去时间且path/domain严格匹配;httponly cookie完全不可被js访问,用于防护xss。

javascript如何操作cookies_有哪些安全考量【教程】

JavaScript 可以读写 document.cookie,但不能直接访问 HttpOnly Cookie;安全上必须防范 XSS、避免明文存敏感信息、始终配合 SameSite 和 Secure 属性。

如何用 document.cookie 读写 Cookie

它不是对象,而是个怪异的字符串接口:读取返回分号分隔的键值对(含过期、路径等),写入需手动拼接完整字符串。没有内置的解析或删除方法。

  • 设置 Cookie:document.cookie = "token=abc123; expires=Fri, 31 Dec 2027 23:59:59 GMT; path=/; secure; SameSite=Lax"
  • 读取时只能拿到所有非 HttpOnly 的 Cookie 字符串,比如 "user_id=42; theme=dark",需自己用 split('; ')split('=') 解析
  • 删除 Cookie:把 expires 设为过去时间,且 pathdomain 必须与原设置完全一致,否则删不掉

为什么 document.cookie 读不到某些 Cookie

只要服务端在 Set-Cookie 响应头里加了 HttpOnly 标志,JS 就完全无法读取或修改该 Cookie —— 这是浏览器强制的安全隔离,不是权限问题,也不是代码写错了。

  • 常见于 session ID、JWT 等后端验证凭证,目的就是防 XSS 盗取
  • document.cookie 只暴露非 HttpOnly 的 Cookie,哪怕你用 DevTools 看 Network → Response Headers 明确看到了 Set-Cookie: auth=xxx; HttpOnly,JS 也拿不到
  • 别试图绕过:没有 API、没有钩子、没有例外

SameSite、Secure、Path 这些属性怎么选

它们不是可有可无的修饰,而是决定 Cookie 是否被发送的关键开关,配错就等于功能失效或埋下漏洞。

易语言学习手册 十天学会易语言图解教程  pdf版
易语言学习手册 十天学会易语言图解教程 pdf版

十天学会易语言图解教程用图解的方式对易语言的使用方法和操作技巧作了生动、系统的讲解。需要的朋友们可以下载看看吧!全书分十章,分十天讲完。 第一章是介绍易语言的安装,以及运行后的界面。同时介绍一个非常简单的小程序,以帮助用户入门学习。最后介绍编程的输入方法,以及一些初学者会遇到的常见问题。第二章将接触一些具体的问题,如怎样编写一个1+2等于几的程序,并了解变量的概念,变量的有效范围,数据类型等知识。其后,您将跟着本书,编写一个自己的MP3播放器,认识窗口、按钮、编辑框三个常用组件。以认识命令及事件子程序。第

下载

立即学习Java免费学习笔记(深入)”;

  • Secure:必须搭配 HTTPS,HTTP 站点设了也无效;开发时 localhost 默认被浏览器视为安全上下文,可临时忽略
  • SameSite=Lax(推荐默认值):跨站 GET 请求(如链接跳转)会带 Cookie,POST 表单提交或 fetch 不会;Strict 太严,None 必须配 Secure,否则被拒
  • Path=/admin:只在 /admin 及其子路径下发送;漏写或写错路径(比如写成 /admin/ 却访问 /admin)会导致 Cookie 不生效

哪些数据绝对不该存在 Cookie 里

只要 JS 能读到,就等于可能被 XSS 脚本一键窃取。哪怕加了加密,只要密钥也在前端,就形同虚设。

  • 密码、身份证号、银行卡号、完整手机号(脱敏后可存,如 138****1234
  • 未过期的长期 token(如 refresh token),应由后端保管并用 HttpOnly + Secure 发送
  • 用户权限列表(role: ["admin"])、未签名的用户 ID——这些应由后端校验,前端只做 UI 降级,不用于鉴权逻辑

Cookie 的边界其实很窄:它只是 HTTP 请求自动携带的一小段状态标识,不是客户端数据库。真正复杂的用户态管理,该走 IndexedDB 或内存缓存,而不是往 document.cookie 里硬塞。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6498

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

368

2023.11.23

阻止所有cookie什么意思
阻止所有cookie什么意思

阻止所有cookie意味着在浏览器中禁止接受和存储网站发送的cookie。阻止所有cookie可能会影响许多网站的使用体验,因为许多网站使用cookie来提供个性化服务、存储用户信息或跟踪用户行为。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

443

2024.02.23

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

334

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

775

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6559

2023.09.14

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号