GolangCookie管理:SetCookie与获取方法详解
时间:2026-01-06 19:47:42 349浏览 收藏
Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《Golang中Cookie管理:SetCookie与获取方法详解》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!
Go中Cookie管理需用http.SetCookie设置和r.Cookie()获取,自动编码/解码、支持HttpOnly/Secure/SameSite等安全属性,并注意Domain限制与删除机制。

在 Go 的 net/http 包中,Cookie 管理主要通过 http.SetCookie 设置和 r.Cookies() 或 r.Cookie(name) 获取实现。核心在于理解 Cookie 是 HTTP 响应头(Set-Cookie)和请求头(Cookie)中的文本字段,Go 提供了结构化封装来安全操作。
使用 http.SetCookie 设置 Cookie
不能直接拼接字符串写入响应头,必须用 http.SetCookie —— 它会自动编码值、生成合法的 Set-Cookie 头,并处理特殊字符、过期时间格式等细节。
- 创建
http.Cookie结构体实例,至少指定Name和Value Value会自动被 URL 编码(如空格变%20),无需手动调用url.QueryEscape- 设置
Expires(绝对时间)或MaxAge(秒数)控制有效期;两者都未设则为会话 Cookie(浏览器关闭即失效) - 敏感 Cookie 应设置
HttpOnly: true(防 XSS 读取)、Secure: true(仅 HTTPS 传输)、SameSite(防 CSRF)
示例:
cookie := &http.Cookie{
Name: "session_id",
Value: "abc123xyz",
Path: "/",
Domain: "example.com", // 注意:localhost 不支持 Domain,留空或设为 ""
MaxAge: 3600,
HttpOnly: true,
Secure: true, // 开发时若无 HTTPS,可临时设 false
SameSite: http.SameSiteLaxMode,
}
http.SetCookie(w, cookie)
从请求中获取 Cookie
客户端发起请求时,浏览器自动在 Cookie 请求头中携带匹配的 Cookie 字符串(如 session_id=abc123xyz; theme=dark)。Go 自动解析并提供两种常用方式:
r.Cookie("name"):返回单个 *http.Cookie,如果不存在则返回nil, ErrNoCookier.Cookies():返回所有 Cookie 的[]*http.Cookie切片(按请求头中出现顺序)
使用示例:
cookie, err := r.Cookie("session_id")
if err == http.ErrNoCookie {
// Cookie 未携带,可能需跳转登录
http.Redirect(w, r, "/login", http.StatusFound)
return
}
if err != nil {
http.Error(w, "读取 Cookie 失败", http.StatusBadRequest)
return
}
fmt.Println("值:", cookie.Value) // 自动 URL 解码,无需手动处理
注意安全性与常见陷阱
Cookie 看似简单,但误用易引发安全问题或行为异常:
- 不要用 Cookie 存储敏感信息(如密码、token 明文),应存服务端 session ID 并配合签名/加密校验
- 设置
Domain时,本地开发用localhost无法设置带 Domain 的 Cookie(浏览器策略限制),建议开发时留空 - 多个同名 Cookie(不同 Path/Domain)可能共存,
r.Cookie(name)返回第一个匹配的,不保证是你要的那个 - 修改 Cookie 时,必须用相同
Name、Path、Domain参数重新调用http.SetCookie才能覆盖 - 删除 Cookie:设置
MaxAge: 0或Expires: time.Unix(0, 0),并确保Path和Domain与原设置一致
进阶:签名与加密 Cookie(推荐用于轻量状态)
若需让 Cookie 自包含且防篡改(如“记住我”功能),不应自己实现加解密,而应使用成熟库如 gorilla/securecookie 或 golang.org/x/crypto/nacl/secretbox。例如:
- 用
securecookie对值签名 + 可选加密,再塞进普通 Cookie - 服务端只验证签名有效性,不依赖后端存储,降低状态耦合
- 避免手写 Base64 或简单 XOR —— 安全性无保障
基本上就这些。Cookie 管理本身不复杂,但细节决定是否健壮和安全。用对 http.SetCookie 和 r.Cookie,再守住安全边界,就够日常用了。
今天关于《GolangCookie管理:SetCookie与获取方法详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
-
369 收藏
-
119 收藏
-
164 收藏
-
199 收藏
-
478 收藏
-
442 收藏
-
190 收藏
-
164 收藏
-
495 收藏
-
175 收藏
-
305 收藏
-
485 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习