news 2026/5/10 9:37:10

c.SetCookie(common.CookieTokenName, token, int(3600*expireHours), “/“, ““, false, true)有什么优势

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
c.SetCookie(common.CookieTokenName, token, int(3600*expireHours), “/“, ““, false, true)有什么优势

这是 Go 语言中设置 HTTP Cookie 的代码,使用了http.SetCookie或框架封装的方法。让我分析这个调用的优势:

参数解析

表格

复制

参数含义
namecommon.CookieTokenNameCookie 名称(通常是 token 或 session ID)
valuetoken实际的认证令牌值
maxAgeint(3600 * expireHours)Cookie 有效期(秒),由小时数动态计算
path"/"整个站点有效
domain""当前域名(不跨域)
securefalse允许 HTTP 传输(不强制 HTTPS)
httpOnlytrue禁止 JavaScript 访问

核心优势

1.动态过期时间计算

go

复制

int(3600 * expireHours)
  • 将小时转换为秒,配置灵活(如 24 小时 = 86400 秒)

  • 便于统一管理会话时长策略

2.HttpOnly = true(安全关键)

  • 防御 XSS 攻击:JavaScript 无法通过document.cookie读取

  • 即使页面被注入恶意脚本,Token 也不会被盗取

  • 这是现代 Web 应用的安全基线要求

3.Path = "/"(全站可用)

  • 用户在整个域名下保持登录状态

  • 避免子路径重复登录的糟糕体验

4.Domain = ""(限制作用域)

  • 仅对当前域名有效,不扩散到子域

  • 减少 CSRF 攻击面(配合其他措施)


⚠️ 潜在改进建议

表格

复制

当前设置建议原因
Secure: false生产环境设为true防止中间人窃听,强制 HTTPS 传输
SameSite未设置添加SameSite=Lax/Strict防御 CSRF 攻击
过期时间硬编码使用配置中心/环境变量便于不同环境调整

更安全的写法示例:

go

复制

c.SetCookie( common.CookieTokenName, token, int(3600*expireHours), "/", "", true, // Secure: 生产环境强制 HTTPS true, // HttpOnly: 防 XSS ) // 同时设置 SameSite 属性(根据框架支持)

总结

这段代码的主要优势在于XSS 防护(HttpOnly)灵活的会话管理,但生产环境建议启用Secure标志并补充SameSite属性,形成完整的 Cookie 安全策略。

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

用过才敢说! 降AIGC网站 千笔·专业降AIGC智能体 VS 学术猹,MBA专属更高效

在AI技术迅速发展的背景下,越来越多的学生和研究人员开始借助AI工具提升论文写作效率。然而,随着学术审查标准的不断升级,AI生成内容的痕迹和重复率问题日益凸显,成为影响论文通过率的关键障碍。许多学生在使用各类降AI率和降重复…

作者头像 李华
网站建设 2026/5/1 9:13:51

百考通问卷结构设计:从“随意提问“到“精准布局“

在教育研究、市场调研、学术课题中,问卷调查是获取一手数据的核心工具。然而,传统问卷设计常面临重重挑战:问题设置不专业导致数据无效,问卷结构混乱影响回收率,数据分析繁琐耗时,学术规范难以把控……当研…

作者头像 李华
网站建设 2026/5/1 6:30:45

基于SpringBoot+Vue的高校器材管理系统的设计与实现

前言 🌞博主介绍:✌CSDN特邀作者、全栈领域优质创作者、10年IT从业经验、码云/掘金/知乎/B站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发、文档编写、答疑辅导等。✌…

作者头像 李华