zoukankan      html  css  js  c++  java
  • Iris_cookie和session

    3. Session的使用和控制

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

    3.1 Session与Cookie的区别

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

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

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

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

    3.2 Session对象创建

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

     sessionID := "mySession"
     //session的创建
     sess := sessions.New(sessions.Config{
             Cookie: sessionID,
     })

    3.3 支持的数据类型

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

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

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

    3.4 Session的使用

     session := sess.Start(ctx)
     session.Set("key", "helloworld")

    4. 实战项目资源导入和项目框架搭建

    从本节内容开始,我们将利用我们所学习的Iris框架的相关知识,进行实战项目开发。

    4.1 实战项目框架搭建

    我们的实战项目是使用Iris框架开发一个关于本地服务平台的后台管理平台。平台中可以管理用户、商品、商铺等相关的信息,平台可以实时展示用户、商品等相关监测数据的变化情况。通过此项目,旨在能够将Iris框架相关的知识得到巩固和练习。 如下是项目框架搭建后的说明:

    • config:项目配置文件及读取配置文件的相关功能

    • controller:控制器目录、项目各个模块的控制器及业务逻辑处理的所在目录

    • datasource:实现mysql连接和操作、封装操作mysql数据库的目录。

    • model:数据实体目录,主要是项目中各业务模块的实体对象的定义

    • service:服务层目录。用于各个模块的基础功能接口定义及实现,是各个模块的数据层。

    • static:配置项目的静态资源目录。

    • util:提供通用的方法封装。

    • main.go:项目程序主入口

    • config.json:项目配置文件。

    5. 代码

    package main
    
    import (
    	"github.com/kataras/iris/sessions"
    	"github.com/kataras/iris"
    	"github.com/kataras/iris/context"
    	"github.com/kataras/iris/sessions/sessiondb/boltdb"
    )
    
    var (
    	USERNAME = "userName"
    	ISLOGIN  = "isLogin"
    )
    
    //Session的使用和控制
    func main() {
    
    	app := iris.New()
    
    	sessionID := "mySession"
    
    	//1.创建session并进行使用
    	sess := sessions.New(sessions.Config{
    		Cookie: sessionID,
    	})
    
    	//用户登录功能
    	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("账户未登录")
    		}
    
    	})
    
    	//2.session和db绑定使用
    	//boltdb键值对的输数据库
    	db, err := boltdb.New("sessions.db", 0600) //0600操作权限
    	if err != nil {
    		panic(err.Error())
    	}
    
    	//程序中断时,将数据库关闭
    	iris.RegisterOnInterrupt(func() {
    		defer db.Close()
    	})
    
    	//session和db绑定
    	sess.UseDatabase(db)
    
    	app.Run(iris.Addr(":8009"), iris.WithoutServerError(iris.ErrServerClosed))
    }
    

      

  • 相关阅读:
    安装MySQLdb
    树莓派及其他硬件平台国内外Linux镜像站全汇总
    rpc使用举例
    SAE上安装第三方模块
    【Java】Map
    【Java】判断字符串是否含字母
    【Android Studio】提示代码忽略大小写
    【iOS】Xcode 离线文档
    【iOS】iOS main() 简介
    【eclipse】No enclosing instance of type A is accessible. Must qualify the allocation with an enclosing instance of type A
  • 原文地址:https://www.cnblogs.com/yzg-14/p/12267914.html
Copyright © 2011-2022 走看看