go语言web开发框架_Iris框架讲解(六):Session的使用和控制 3年前

在实际的项目开发中,我们会经常有业务场景使用到Session功能。在iris框架中,也为我们提供了方便使用,功能齐全的Session模块。Session模块的源码目录为kataras/iris/sessions包。

Session与Cookie的区别

在学习web开发过程中,我们总会和session和cookie打交道。本节课我们学习sesion相关的知识,因此有必要先通过讲解对比一下session和cookie的区别:

  • 首先是两者的相同点。session和cookie两者都是用来存储客户的状态信息的手段。在登录、注册等动作后,可以存储相关账户的状态信息,方便程序后续跟踪及使用。

  • 其次是不同点,讨论两者的不同点我们从几个角度来总结。首先是两者的存储位置。Cookie是存储在客户端浏览器上,方便客户端请求时使用;Session存储的相关信息存储在服务器端,用于存储客户端连接的状态信息。

  • 其次,从可以存储的数据类型来看。Cookie仅仅支持存储字符串string一种数据类型,Session支持int、string、bool等多种数据类型,Session支持的数据类型更全更多。

Session对象创建

在实际的程序开发中,iris框架中可以非常方便的创建一个新的session对象。如下所示,即是session的创建:

...  
sessionID := "mySession"  
//session的创建  
sess := sessions.New(sessions.Config{  
 Cookie: sessionID,  
})
支持的数据类型

在上文中,我们说过session支持的数据类型要比cookie多,我们来看一下iris框架中的session所支持存储的数据类型:

//String:字符串类型  
session.GetString()  
//Int:无符号整形 及系列相关单位的同类型  
session.GetInt()  
//Boolean:布尔值类型  
session.GetBoolean()  
//Float:单精度数值类型 及系列相关单位的同类型  
session.GetFloat()  
//interface{}:接口 即任意数据结构类型  
session.GetFlash()

上述代码块,即列出了iris框架中所支持存储的数据类型。我们在接下来的本节课程内容中,将会演示如何进行具体使用。

Session的存储和使用

在实际的项目开发中,Session的用法非常普遍。在本节课堂中,我们通过一个模拟用户登录、登出、查询的案例来模拟Session的存储、使用、删除等操作。

具体案例如下:

app.Post("/login", func(context context.Context) {  
 path := context.Path()  
 app.Logger().Info(" 请求Path:", path)  
 userName := context.PostValue("name")  
 passwd := context.PostValue("pwd")  
​  
 if userName == "davie" && passwd == "pwd123" {  
 session := sess.Start(context)  
​  
 //用户名  
 session.Set(USERNAME, userName)  
 //登录状态  
 session.Set(ISLOGIN, true)  
​  
 context.WriteString("账户登录成功 ")  
​  
 } else {  
 session := sess.Start(context)  
 session.Set(ISLOGIN, false)  
 context.WriteString("账户登录失败,请重新尝试")  
 }  
 })  
 ...  
 app.Get("/logout", func(context context.Context) {  
 path := context.Path()  
 app.Logger().Info(" 退出登录 Path :", path)  
 session := sess.Start(context)  
 //删除session  
 session.Delete(ISLOGIN)  
 session.Delete(USERNAME)  
 context.WriteString("退出登录成功")  
 })  
 ...  
 app.Get("/query", func(context context.Context) {  
 path := context.Path()  
 app.Logger().Info(" 查询信息 path :", path)  
 session := sess.Start(context)  
​  
 isLogin, err := session.GetBoolean(ISLOGIN)  
 if err != nil {  
 context.WriteString("账户未登录,请先登录 ")  
 return  
 }  
​  
 if isLogin {  
 app.Logger().Info(" 账户已登录 ")  
 context.WriteString("账户已登录")  
 } else {  
 app.Logger().Info(" 账户未登录 ")  
 context.WriteString("账户未登录")  
 }  
​  
 })  
 ...

上述的代码中展示了session的使用方法,更多全部的案例代码资料在配套的课程资料中可以查看。

Session与数据库结合使用

除了Session在程序中的使用,Session还可以与数据库绑定使用,用以在停止服务时将用户状态session同步于数据库中,并进行恢复。

db, err := boltdb.New("sessions.db", 0600)  
if err != nil {  
 panic(err.Error())  
}  
​  
//程序中断时,将数据库关闭  
iris.RegisterOnInterrupt(func() {  
 defer db.Close()  
})  
​  
//session和db绑定  
sess.UseDatabase(db)

本节课中,我们学习了Session的操作和使用相关的内容。在后面的实际项目开发中,我们本节课学习的内容将会得到应用实践的机会。

本文转自 https://www.cnblogs.com/qfDavie/p/10622487.html,如有侵权,请联系删除。

image
cheese璟
所谓家嘛,就是一个能让你懒惰、晕眩、疯狂放松的地方。
6
发布数
1
关注者
9077
累计阅读

热门教程文档

React Native
40小节
QT
33小节
Javascript
24小节
Djiango
17小节
Redis
14小节