RedisHashTableStorage
与RedisKeyValueStorage
不同的地方在于RedisHashTableStorage
底层使用HashTable
存储Session
数据,每一次对Session
的增删查改都是直接访问Redis
服务实现(单条数据项操作),不存在像RedisKeyValueStorage
那样初始化全量拉取一次,请求结束后如有修改再全量更新到Redis
服务的操作。
使用示例
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/net/ghttp"
"github.com/gogf/gf/v2/os/gsession"
"github.com/gogf/gf/v2/os/gtime"
"time"
)
func main() {
s := g.Server()
s.SetSessionMaxAge(time.Minute)
s.SetSessionStorage(gsession.NewStorageRedisHashTable(g.Redis()))
s.Group("/", func(group *ghttp.RouterGroup) {
group.ALL("/set", func(r *ghttp.Request) {
r.Session.Set("time", gtime.Timestamp())
r.Response.Write("ok")
})
group.ALL("/get", func(r *ghttp.Request) {
r.Response.Write(r.Session.Data())
})
group.ALL("/del", func(r *ghttp.Request) {
_ = r.Session.RemoveAll()
r.Response.Write("ok")
})
})
s.SetPort(8199)
s.Run()
}
在该实例中,为了方便观察过期失效,我们将Session
的过期时间设置为1分钟
。执行后,
- 首先,访问 http://127.0.0.1:8199/set 设置一个
Session
变量; - 随后,访问 http://127.0.0.1:8199/get 可以看到该
Session
变量已经设置并成功获取; - 接着,我们停止程序,并重新启动,再次访问 http://127.0.0.1:8199/get ,可以看到
Session
变量已经从Redis
存储中恢复;如果我们手动修改Redis
中的对应键值数据,页面刷新时也会读取到最新的值; - 等待1分钟后,再次访问 http://127.0.0.1:8199/get 可以看到已经无法获取该
Session
,因为该Session
已经过期;