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

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

Session与Cookie的区别

在学习web开发过程当中,咱们总会和session和cookie打交道。本节课咱们学习sesion相关的知识,所以有必要先经过讲解对比一下session和cookie的区别:数据库

  • 首先是二者的相同点。session和cookie二者都是用来存储客户的状态信息的手段。在登陆、注册等动做后,能够存储相关帐户的状态信息,方便程序后续跟踪及使用。浏览器

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

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

Session对象建立

在实际的程序开发中,iris框架中能够很是方便的建立一个新的session对象。以下所示,便是session的建立:cookie

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

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

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

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

Session的存储和使用

在实际的项目开发中,Session的用法很是广泛。在本节课堂中,咱们经过一个模拟用户登陆、登出、查询的案例来模拟Session的存储、使用、删除等操做。app

具体案例以下:框架

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的操做和使用相关的内容。在后面的实际项目开发中,咱们本节课学习的内容将会获得应用实践的机会。

相关文章
相关标签/搜索