Gin-session中Redis-based session的原理

本文深入分析了Gin框架下基于Redis的session实现,详细讲解了session.Sessions中间件、Handler中获取、设置和保存session的流程。通过源码解读,展示了如何在Handler中使用session,以及session的保存过程,包括在Redis中的存储和cookie中的设置。最后,文章提到了Redis-based session的典型应用场景,即用户登录后的鉴权过程。
摘要由CSDN通过智能技术生成

Gin session库

本文讨论的Gin相关的session库为:https://github.com/gin-contrib/sessions

Redis-based session源码分析

gin-contrib/sessions这个库支持多种session的实现,例如:cookie-based session / Redis-based session / memcached Session。这里我们主要分析Redis-based session的实现代码。cookie-based session和Redis-based session的优缺点比较:

优点 缺点
cookie-based 简单,无需引入第三方存储,不占用服务器存储资源 不安全,受浏览器限制,控制起来不灵活(例如从服务端设置“登出”用户)
Redis-based 相对安全,控制更加灵活,适合存敏感信息 占用服务器资源
session.Sessions中间件

在Gin中,通常以中间件的方式进行session管理。中间件的使用方式,我们应该都已经比较熟悉了。相应的HandlerFunc在gin-contrib/sessionssessions.go中:

func Sessions(name string, store Store) gin.HandlerFunc {
   
	return func(c *gin.Context) {
   
		s := &session{
   name, c.Request, store, nil, false, c.Writer}
		c.Set(DefaultKey, s)
		defer context.Clear(c.Request)
		c.Next()
	}
}

这里就干了一件事情:把request和store信息Set到Gin context中的Keys里,方便Handler中进行使用。这里的store为redis的接口。由此可以判断,业务Handler中肯定是从context里取出session,进行应用,我们后面来验证。

Handler中获取session

在Handler中,我们通过session := sessions.Default(c)来获取session,从而对session进行检查和处理。

sessions.go:

// shortcut to get session
func Default(c *gin.Context) Session {
   
	return c.MustGet(DefaultKey).(Session)
}
Handler中Set & Save session

Set()和Save()分别是设置和保存session信息的方法。gin-contrib/sessions的底层引用的是gorilla/sessions,Session struct的结构如下,其中的Values这个map用于存储session信息的键值对。

// Session stores the values and optional configuration for a session.
type Session struct {
   
	// The ID of the session, generated by stores. It should not be used for
	// user data.
	ID string
	// Values contains the user-data for the session.
	Values  map[interface{
   }]interface{
   }
	Options *Options
	IsNew   bool
	store   Store
	name    string
}

所以Set()方法更新的是上面的Values:

func 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
gin-admin-api是一个基于Gin框架开发的后台管理系统的API接口。Gin框架是一个轻量级的、高性能的Go语言框架,具有路由和间件的功能,适合用于构建Web应用程序。 gin-admin-api提供了一套完善的API接口,用于实现后台管理系统的各种功能,例如用户管理、角色管理、权限管理、菜单管理、日志管理等。通过这些接口,可以方便地进行用户的注册、登录和认证,管理用户的角色和权限,管理系统的菜单和日志信息。 gin-admin-api的优点之一是高性能。由于采用了Gin框架,它具有快速的路由匹配和间件处理的能力,能够处理大量的请求,并在高并发的情况下保持稳定性和可靠性。 另一个优点是易于扩展和定制。gin-admin-api使用了模块化的设计,各个功能模块之间松耦合,可以根据实际需求进行灵活的扩展和定制。例如,可以根据业务需求添加新的功能模块,或者修改和优化已有的模块。 此外,gin-admin-api还提供了友好的文档和示例代码,方便开发者理解和使用。它的源代码也是开源的,可以在GitHub上找到,这样可以方便地进行二次开发和定制,满足特定的业务需求。 总之,gin-admin-api是一个功能丰富、高性能、易扩展的后台管理系统API接口,大大简化了后台管理系统的开发工作,帮助开发者快速构建稳定、可靠的后台管理系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值