0

0

如何在Golang中实现Cookie管理_使用http.SetCookie和获取Cookie

P粉602998670

P粉602998670

发布时间:2025-12-29 19:15:08

|

158人浏览过

|

来源于php中文网

原创

Go中Cookie管理需用http.SetCookie设置和r.Cookie()获取,自动编码/解码、支持HttpOnly/Secure/SameSite等安全属性,并注意Domain限制与删除机制。

如何在golang中实现cookie管理_使用http.setcookie和获取cookie

在 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 结构体实例,至少指定 NameValue
  • 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 自动解析并提供两种常用方式:

立即学习go语言免费学习笔记(深入)”;

Figma
Figma

Figma 是一款基于云端的 UI 设计工具,可以在线进行产品原型、设计、评审、交付等工作。

下载
  • r.Cookie("name"):返回单个 *http.Cookie,如果不存在则返回 nil, ErrNoCookie
  • r.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 时,必须用相同 NamePathDomain 参数重新调用 http.SetCookie 才能覆盖
  • 删除 Cookie:设置 MaxAge: 0Expires: time.Unix(0, 0),并确保 PathDomain 与原设置一致

进阶:签名与加密 Cookie(推荐用于轻量状态)

若需让 Cookie 自包含且防篡改(如“记住我”功能),不应自己实现加解密,而应使用成熟库如 gorilla/securecookiegolang.org/x/crypto/nacl/secretbox。例如:

  • securecookie 对值签名 + 可选加密,再塞进普通 Cookie
  • 服务端只验证签名有效性,不依赖后端存储,降低状态耦合
  • 避免手写 Base64 或简单 XOR —— 安全性无保障

基本上就这些。Cookie 管理本身不复杂,但细节决定是否健壮和安全。用对 http.SetCookier.Cookie,再守住安全边界,就够日常用了。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

335

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

187

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

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

精品课程

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

共32课时 | 3.1万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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