0

0

如何在 Go 中正确删除 HTTP Cookie

聖光之護

聖光之護

发布时间:2026-01-12 13:38:59

|

430人浏览过

|

来源于php中文网

原创

如何在 Go 中正确删除 HTTP Cookie

go 中删除 http cookie 需显式设置同名、同路径、同域的 cookie,将其 maxage 设为 -1 并指定过期时间(兼容旧版 ie),**不能复用 `r.cookie()` 返回的原始 cookie 实例**。

要真正从客户端浏览器中移除一个 Cookie,本质是向浏览器发送一条“覆盖指令”:用一个同名、同路径(Path)、同域名(Domain)、且已过期的 Cookie 替换原有 Cookie。浏览器收到后会立即丢弃它。

关键点在于:*不能直接修改 r.Cookie("login") 返回的 `http.Cookie并重设**——因为该实例包含服务端接收到的原始值(如Value、Path、Domain等可能不完整或不匹配),尤其Path和Domain` 若缺失或错误,会导致新 Cookie 无法匹配原 Cookie 而无法覆盖。

✅ 正确做法是全新构造一个 http.Cookie 实例,并确保以下字段与原始 Cookie 严格一致:

  • Name:必须完全相同(如 "login");
  • Path:必须与设置时使用的 Path 一致(常见为 /,但若当初设为 /auth,此处也必须为 /auth);
  • Domain:若原 Cookie 指定了 Domain(如 .example.com),此处也需显式指定;
  • MaxAge:设为 -1,表示立即过期;
  • Expires:设为过去的时间(如 time.Now().Add(-100 * time.Hour)),这是对老旧浏览器(尤其是旧版 IE)的必要兼容措施;
  • Value:可为空字符串,但非必需;浏览器只认 MaxAge 和 Expires 是否过期。

示例代码如下:

顶级域名交易系统
顶级域名交易系统

1.后台管理登陆直接在网站地址后输入后台路径,默认为 /admin,进入后台管理登陆页面,输入管理员用户名和密码,默认为 中文 admin ,登陆后台。2.后台管理a.注销管理登陆 (离开后台管理时,请点击这里正常退出,确保系统安全)b.查看使用帮助 (如果你在使用系统时,有不清楚的,可以到这里来查看)c.管理员管理 (这里可以添加,修改,删除系统管理员,暂不支持,分权限管理操作)d.分类管理 (

下载
func deleteLoginCookie(w http.ResponseWriter, r *http.Request) {
    // 假设原始 cookie 是通过 Path="/" 设置的
    pathUsedToSetCookie := "/"

    cookie := &http.Cookie{
        Name:     "login",
        Value:    "",
        Path:     pathUsedToSetCookie,
        MaxAge:   -1,
        Expires:  time.Now().Add(-100 * time.Hour),
        HttpOnly: true, // 若原 cookie 含 HttpOnly,建议保持一致(非强制但推荐)
        Secure:   r.TLS != nil, // 若仅在 HTTPS 下设置,此处也应设 Secure=true
    }
    http.SetCookie(w, cookie)
}

⚠️ 注意事项:

  • Path 是最易被忽略的关键字段:Go 默认 SetCookie 的 Path 是请求路径(如 /user/logout),而非根路径 /。务必确认原始 Cookie 的 Path,并在删除时完全复现;
  • 不要依赖 r.Cookie("login") 的 Path 字段——它可能为空或不准确(浏览器只发送 Name=Value,Path/Domain 等元数据不会回传);
  • 若 Cookie 是跨子域共享的(如 Domain=".example.com"),删除时 Domain 必须完全一致;
  • HttpOnly 和 Secure 标志无需匹配才能删除,但保持一致更利于调试和安全一致性;
  • 删除操作本身无返回值,可通过浏览器开发者工具 → Application → Cookies 验证是否已清除。

总结:删除 Cookie 不是“删除动作”,而是“覆盖为已过期状态”。核心原则是——同名、同路径、同域、过期时间置为过去。只要这四点精准匹配,浏览器便会可靠移除对应 Cookie。

相关专题

更多
cookie
cookie

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

6415

2023.06.30

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

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

340

2023.11.23

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

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

405

2024.02.23

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

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

88

2025.08.19

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

254

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1463

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

617

2023.11.24

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

9

2026.01.12

热门下载

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

精品课程

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

共32课时 | 3.6万人学习

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

共10课时 | 0.8万人学习

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

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