发布时间:2022-12-06 文章分类:编程知识 投稿人:李佳 字号: 默认 | | 超大 打印

在我的客服系统项目中,我使用的gin框架没有自带session功能,需要经过下面的整合处理

使用的是github.com/gin-contrib/sessions

在我的tools包下

package tools
import (
    "github.com/gin-contrib/sessions"
    "github.com/gin-contrib/sessions/cookie"
    "github.com/gin-gonic/gin"
)
// 中间件,处理session
func Session(keyPairs string) gin.HandlerFunc {
    store := SessionConfig()
    return sessions.Sessions(keyPairs, store)
}
func SessionConfig() sessions.Store {
    sessionMaxAge := 3600
    sessionSecret := "kefu"
    var store sessions.Store
    store = cookie.NewStore([]byte(sessionSecret))
    store.Options(sessions.Options{
        MaxAge: sessionMaxAge, //seconds
        Path:   "/",
    })
    return store
}

gin框架use一下这个中间件

engine.Use(tools.Session("kefu"))

实际存储数据和读取数据

func GetCaptchaV2(c *gin.Context) {
    session := sessions.Default(c)
    session.Set("name", "red")
    session.Save()
}
func GetCaptchaV2(c *gin.Context) {
    session := sessions.Default(c)
    session.Get("name")
}

上面就是存储一个键值对,然后读取这个key的值,这个是基于cookie实现的,也就是内容被加密存储在cookie里面了。

每次从cookie里读取并解密出来,还有其他存储引擎就不进行测试了。

利用这个seesion功能可以实现登录状态验证,或者我后面的验证码的验证实现。