gpt4 book ai didi

go - gorilla cookie session 会持续服务器重建吗?

转载 作者:数据小太阳 更新时间:2023-10-29 03:22:24 26 4
gpt4 key购买 nike

我正在使用以下代码在我的包中传递当前 session 。我正在用 fresh 构建它来监视我的文件。似乎在构建 cookie 后不再有效?我已经尝试过 cookie 存储和 mysql 存储。我已确认 cookie 仍在浏览器中,行项目仍在数据库中。

var sessionStore = sessions.NewCookieStore([]byte(os.Getenv("SESSION_SECRET")))


var sessionPointer *sessions.Session;


func initSession(r *http.Request) *sessions.Session {


if sessionPointer == nil {

} else{
return sessionPointer;
}


temp, err := sessionStore.Get(r,os.Getenv("SESSION_NAME"))

sessionPointer = temp;

sessionPointer.Options = &sessions.Options{

Path: "/",

MaxAge: 86400 * 1,

HttpOnly: false,

}

if err != nil {
panic(err)
}
return sessionPointer
}

最佳答案

问题很可能是您正在“共享” session 。一个 session 应该属于一个请求。但是当你这样做时:

var sessionPointer *sessions.Session; 


func initSession(r *http.Request) *sessions.Session {
if sessionPointer == nil {

} else{
return sessionPointer;
}


temp, err := sessionStore.Get(r,os.Getenv("SESSION_NAME"))

sessionPointer = temp;

// ...
}

您实际上是在说“如果任何 session 已创建,则返回它”。这意味着每个请求(和每个用户)都将获得相同的 session 。我不确定他们是如何将请求与特定 session 匹配的,但我认为每次将它与新请求匹配时都不会调用 sessionStore.Get,最终会设置一些东西使其不再有效的 session (因为该 session 实际上并不属于该请求)。

好消息是没有理由缓存sessionPointer。无论如何,它在内部使用 map ,而且查找基本上是免费的。我会将您的代码更改为:

func initSession(r *http.Request) *sessions.Session {
temp, err := sessionStore.Get(r,os.Getenv("SESSION_NAME"))
if err != nil {
panic(err)
}
sessionPointer.Options = &sessions.Options{
Path: "/",
MaxAge: 86400 * 1,
HttpOnly: false,
}
return sessionPointer
}

然后我会认为一切都会按预期进行。

关于go - gorilla cookie session 会持续服务器重建吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51524698/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com