1 Star 0 Fork 2

秋天的童话 / sessions

forked from dxvgef / sessions 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

Sessions

使用golang实现的Sessions功能包,仅支持Redis存储,Redis的驱动包使用的是go-redis/redis,已实现以下功能:

  • 写入指定键名的值
  • 根据键名读取值并转换类型
  • 根据键名删除值
  • 清除所有Session数据但保留Cookie中的SessionID
  • 清除所有Session数据以及Cookie中的SessionID,下次请求时重新生成新的SessionID
  • 默认自动自动更新Session空闲时间,可禁止自动更新

使用示例

此示例的HTTP框架使用的是Tsing,也可以和更多框架整合

package main

import (
	"log"
	"net/http"
	"time"

	"github.com/dxvgef/tsing"
	"github.com/dxvgef/sessions"
)

// 定义session管理器
var sessManager sessions.SessionManager

func main() {
	log.SetFlags(log.Lshortfile)

	// 设置session管理器
	err := setSessManager()
	if err != nil {
		log.Fatalln(err.Error())
	}

	app := tsing.New()

	// 定义一个路由处理器用于写入session
	app.Router.GET("/", func(ctx tsing.Context) error {
		// 启用session
		session, err := sessManager.UseSession(ctx.Request, ctx.ResponseWriter)
		if err != nil {
			log.Println(err.Error())
			return err
		}
		// 写入值
		err = session.Set("test", "ok")
		return err
	})

	// 定义一个路由处理器用于演示sessions的其它操作
	app.Router.GET("/test", func(ctx tsing.Context) error {
		// 启用session
		session, err := sessManager.UseSession(ctx.Request, ctx.ResponseWriter)
		if err != nil {
			log.Println(err.Error())
			return err
		}
		// 读取string类型的值
		var value string
		value, err = session.Get("test").String()
		if err != nil {
			log.Println(err.Error())
			return err
		}
		ctx.ResponseWriter.WriteHeader(200)
		ctx.ResponseWriter.Write([]byte(value))

		// 删除指定key的数据
		err = session.Delete("test")
		if err != nil {
			log.Println(err.Error())
			return err
		}
		// 清除session数据但不删除cookie中的sessionID
		err = session.ClearData()
		if err != nil {
			log.Println(err.Error())
			return err
		}
		// 清除session数据以及cookie中的sessionID
		// 下次请求时会重新生成新的sessionID
		err = sessManager.ClearAll(ctx.Request, ctx.ResponseWriter)
		if err != nil {
			log.Println(err.Error())
			return err
		}
		return nil
	})

	// 启动HTTP服务
	if err := http.ListenAndServe(":8080", app); err != nil {
		log.Fatal(err.Error())
	}
}

// 设置sessionManager
func setSessManager() error {
	var err error
	// 创建session管理器
	sessManager, err = sessions.NewSessions(sessions.Config{
		CookieName:                 "sessionid",        // cookie中的sessionID名称
		HttpOnly:                   true,               // 仅允许HTTP读取,js无法读取
		Domain:                     "",                 // 作用域名,留空则自动获取当前域名
		Path:                       "/",                // 作用路径
		MaxAge:                     60 * 60,            // 最大生命周期(秒)
		IdleTime:                   20 * time.Minute,   // 空闲超时时间
		Secure:                     false,              // 启用HTTPS
		DisableAutoUpdateIdleTime:  false,              // 禁止自动更新空闲时间
		RedisAddr:                  "127.0.0.1:32771",  // Redis地址
		RedisDB:                    0,                  // Redis数据库
		RedisPassword:              "",                 // Redis密码
		RedisKeyPrefix:             "sess",             // Redis中的键名前缀,必须
		Key:                        "abcdefghijklmnop", // 用于加密sessionID的密钥,密钥的长度16,24,32对应AES-128,AES-192,AES-256算法
	})
	if err != nil {
		return err
	}
	return nil
}

空文件

简介

Go语言开发的Session包,存储引擎使用Redis,通用于Go语言的HTTP标准包及大部份Web框架 展开 收起
Go
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
Go
1
https://gitee.com/skygf163/sessions.git
git@gitee.com:skygf163/sessions.git
skygf163
sessions
sessions
master

搜索帮助