当前位置:首页 > 文章列表 > Golang > Go问答 > 浏览器不存储来自Golang后端的cookie信息

浏览器不存储来自Golang后端的cookie信息

来源:stackoverflow 2024-02-07 14:27:22 0浏览 收藏

一分耕耘,一分收获!既然都打开这篇《浏览器不存储来自Golang后端的cookie信息》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新Golang相关的内容,希望对大家都有所帮助!

问题内容

我知道这个问题已经被问过很多次了,但我尝试了大部分答案,但仍然无法让它发挥作用。

我有一个带有 net/http 包和 js 前端的 golang api。我有一个函数

func setcookie(w *http.responsewriter, email string) string {
    val := uuid.newstring()
    http.setcookie(*w, &http.cookie{
        name:     "gocookie",
        value:    val,
        path:     "/",
    })
    return val
}

该函数在用户登录时被调用,我希望它被发送到所有其他端点。这与 postman 的预期一致。但是,当涉及到浏览器时,我似乎无法让它记住 cookie,甚至无法将其发送到其他端点。

使用端点的 js 示例

async function getDataWithQuery(query, schema){
    
    let raw = `{"query":"${query}", "schema":"${schema}"}`;
    let requestOptions = {
        method: 'POST',
        body: raw,
        redirect: 'follow',
    };
    try{
        let dataJson = await fetch("http://localhost:8080/query/", requestOptions)
        data = await dataJson.json();
    }catch(error){
        console.log(error);
    }

    return data;
}

我尝试过在 golang 中设置 samesite 属性,或在 js 中使用 credential: "include" 等答案,但没有成功。


正确答案


感谢评论中的讨论,我找到了一些有关该问题的提示。

保存 cookie(api 和前端位于同一主机上)

我使用document.cookie来保存cookie。我手动设置选项,因为在 api fetch 的响应上调用 res.cookie 仅返回值。一个例子是 document.cookie = `gocookie=${res.cookie};路径=/;域=localhost;

发送cookie

这个问题已经在之前的问题中回答过,并在评论中再次回答过。问题是我使用了 credential:'include' 而不是正确的 credentials:'include' (复数)。

cors 和 cookie

如果 api 和前端不在同一主机上,您将必须同时修改 api 和前端。

前端

cookie 必须具有 api 的域,因为是 api 需要它,而不是前端。因此,出于安全原因,您无法为另一个域(前端)的域(api)设置 cookie。解决方案是将用户重定向到 api 端点,该端点在响应标头中返回 set-cookie 标头。此解决方案指示浏览器使用附加的域(api 的域,因为 api 发送了它)来注册该 cookie。

此外,您仍然需要在前端包含 credentials:'include'

api

您需要设置一些标头。我设置的是

    w.header().set("access-control-allow-origin", frontendorigin)
    w.header().set("access-control-allow-credentials", "true")
    w.header().set("access-control-allow-headers", "content-type, withcredentials")
    w.header().set("access-control-allow-methods", method) // use the endpoint's method: post, get, options

您需要公开前端将重定向用户并在响应中设置 cookie 的端点。您可以省略它,而不是手动设置 api 的域,浏览器会自动用域填充它。

要处理 cors 并让 js 成功发送 cookie,您必须在 cookie 中设置 samesite=nonesecure 属性,并通过 https 提供 api(为了简单起见,我使用了 ngrok)。

像这样

func SetCookie(w *http.ResponseWriter, email string) string {
    val := uuid.NewString()
    http.SetCookie(*w, &http.Cookie{
        Name:     "goCookie",
        Value:    val,
        SameSite: http.SameSiteNoneMode,
        Secure:   true,
        Path:     "/",
    })
   // rest of the code
}

我建议您还阅读使用 localstoragedocument.cookie 之间的区别,这是我遇到的问题之一。

希望这有帮助。

好了,本文到此结束,带大家了解了《浏览器不存储来自Golang后端的cookie信息》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
理解第21行中的 .(Cat) 的用法是什么?理解第21行中的 .(Cat) 的用法是什么?
上一篇
理解第21行中的 .(Cat) 的用法是什么?
学习正确使用 API 密钥的第三方实施方法
下一篇
学习正确使用 API 密钥的第三方实施方法
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO标题魔匠AI:高质量学术写作平台,毕业论文生成与优化专家
    魔匠AI
    SEO摘要魔匠AI专注于高质量AI学术写作,已稳定运行6年。提供无限改稿、选题优化、大纲生成、多语言支持、真实参考文献、数据图表生成、查重降重等全流程服务,确保论文质量与隐私安全。适用于专科、本科、硕士学生及研究者,满足多语言学术需求。
    11次使用
  • PPTFake答辩PPT生成器:一键生成高效专业的答辩PPT
    PPTFake答辩PPT生成器
    PPTFake答辩PPT生成器,专为答辩准备设计,极致高效生成PPT与自述稿。智能解析内容,提供多样模板,数据可视化,贴心配套服务,灵活自主编辑,降低制作门槛,适用于各类答辩场景。
    26次使用
  • SEO标题Lovart AI:全球首个设计领域AI智能体,实现全链路设计自动化
    Lovart
    SEO摘要探索Lovart AI,这款专注于设计领域的AI智能体,通过多模态模型集成和智能任务拆解,实现全链路设计自动化。无论是品牌全案设计、广告与视频制作,还是文创内容创作,Lovart AI都能满足您的需求,提升设计效率,降低成本。
    27次使用
  • 美图AI抠图:行业领先的智能图像处理技术,3秒出图,精准无误
    美图AI抠图
    美图AI抠图,依托CVPR 2024竞赛亚军技术,提供顶尖的图像处理解决方案。适用于证件照、商品、毛发等多场景,支持批量处理,3秒出图,零PS基础也能轻松操作,满足个人与商业需求。
    35次使用
  • SEO标题PetGPT:智能桌面宠物程序,结合AI对话的个性化陪伴工具
    PetGPT
    SEO摘要PetGPT 是一款基于 Python 和 PyQt 开发的智能桌面宠物程序,集成了 OpenAI 的 GPT 模型,提供上下文感知对话和主动聊天功能。用户可高度自定义宠物的外观和行为,支持插件热更新和二次开发。适用于需要陪伴和效率辅助的办公族、学生及 AI 技术爱好者。
    36次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码