document.cookie
属性设置Cookie,创建格式为name=value; expires=GMTString; path=/
的字符串并赋值,,“javascript,document.cookie = "username=John; expires=Thu, 18 Dec 2025 12:00:00 UTC; path=/";,
“在HTML中直接设置Cookie是不可行的,因为HTML是标记语言而非编程语言,实际设置Cookie需要通过JavaScript实现,以下是详细的操作指南:
基础设置方法
通过JavaScript的document.cookie
属性实现:
<script> // 设置基础Cookie(会话级,关闭浏览器失效) document.cookie = "username=JohnDoe"; // 设置带过期时间的Cookie(30天后失效) const expiryDate = new Date(); expiryDate.setDate(expiryDate.getDate() + 30); document.cookie = `theme=dark; expires=${expiryDate.toUTCString()}`; </script>
关键参数详解
设置Cookie时可附加以下参数:
-
expires
expires=${new Date(2025, 0, 1).toUTCString()}
(设置2025年1月1日过期) -
max-age(优先级高于expires)
max-age=2592000
// 30天(单位:秒) -
path
path=/admin
// 仅/admin路径可访问 -
domain
domain=.example.com
// 作用于所有子域名 -
Secure(仅HTTPS传输)
Secure
-
HttpOnly(禁止JavaScript访问)
HttpOnly
完整示例
<script> document.cookie = `user_token=abc123xyz; expires=${new Date(Date.now() + 86400000).toUTCString()}; path=/; domain=.yourwebsite.com; Secure; HttpOnly`; </script>
操作函数封装
// 设置Cookie function setCookie(name, value, days=30, path="/") { const expires = new Date(); expires.setTime(expires.getTime() + days*24*60*60*1000); document.cookie = `${name}=${encodeURIComponent(value)}; expires=${expires.toUTCString()}; path=${path}; Secure`; } // 读取Cookie function getCookie(name) { return document.cookie .split('; ') .find(row => row.startsWith(`${name}=`)) ?.split('=')[1]; } // 示例调用 setCookie("language", "zh-CN", 90); console.log(getCookie("language")); // 输出"zh-CN"
安全最佳实践
-
敏感数据保护
- 用户身份凭证必须添加
HttpOnly
和Secure
标志 - 避免存储密码/银行卡号等敏感信息
- 用户身份凭证必须添加
-
同源策略
- Cookie默认仅允许同域名访问
- 跨域需设置
SameSite=None; Secure
-
合规要求
- GDPR/CCPA等法规要求明确告知用户
- 提供Cookie使用声明和禁用选项
浏览器限制
属性 | 限制值 |
---|---|
单条Cookie大小 | 通常4KB(不同浏览器有差异) |
域名Cookie总数 | 约50-150条 |
总存储空间 | 通常3000条左右 |
重要提示:现代网站应优先使用
localStorage
或sessionStorage
存储非敏感数据,仅会话标识等必要数据使用Cookie。
调试与验证
- 浏览器开发者工具 → Application → Cookies
- 查看Cookie的生效参数和值
- 通过控制台执行
document.cookie
查看当前域Cookie
引用说明 参考以下权威来源:
- MDN Web文档 – HTTP Cookies机制(developer.mozilla.org)
- RFC 6265 – HTTP状态管理机制标准(tools.ietf.org)
- OWASP安全指南 – Cookie安全最佳实践(owasp.org)
- Google开发者文档 – 现代Cookie使用策略(developers.google.com)
原创文章,发布者:酷盾叔,转转请注明出处:https://www.kd.cn/ask/33043.html