皇上,还记得我吗?我就是1999年那个Linux伊甸园啊-----24小时滚动更新开源资讯,全年无休!

gtoken v1.1.0 发布,gf 的 token 插件,加入 Redis 缓存支持

gtoken

此版本主要加入了缓存 redis 支持,便于项目集群部署

介绍

基于 gf 框架的 token 插件,通过服务端验证方式实现 token 认证;

  1. 支持单机 gcache 和集群 gredis 模式;
# 配置文件 
# 缓存模式 1 gcache 2 gredis
cache-mode = 2
  1. 支持简单 token 认证
  2. 框架使用简单,只需要设置登录验证方法以及登录、登出、拦截路径即可;

安装教程

gopath 模式: go get https://github.comgoflyfox/gtoken

或者 使用 go.mod 添加 :require github.comgoflyfox/gtoken last

使用说明

只需要配置登录路径、登出路径、拦截路径以及登录校验实现即可

	// 启动 gtoken
	gtoken := &gtoken.GfToken{
		LoginPath:       "/login",
		LoginBeforeFunc: loginFunc,
		LogoutPath:      "/user/logout",
		AuthPaths:       g.SliceStr{"/user/*", "/system/*"},
	}
	gtoken.Start()

登录方法实现

func Login(r *ghttp.Request) (string, interface{}) {
	username := r.GetPostString("username")
	passwd := r.GetPostString("passwd")

	// TODO 进行登录校验

	return username, ""
}

逻辑测试

可运行 api_test.go 进行测试并查看结果;验证逻辑说明:

  1. 访问用户信息,提示未携带 token
  2. 登录后,携带 token 访问正常
  3. 登出成功
  4. 携带之前 token 访问,提示未登录
--- PASS: TestSystemUser (0.00s)
    api_test.go:43: 1. not login and visit user
    api_test.go:50: {"code":-1,"data":"","msg":"query token fail"}
    api_test.go:63: 2. execute login and visit user
    api_test.go:66: {"code":0,"msg":"success","data":"system user"}
    api_test.go:72: 3. execute logout
    api_test.go:75: {"code":0,"msg":"success","data":"logout success"}
    api_test.go:81: 4. visit user
    api_test.go:86: {"code":-1,"msg":"login timeout or not login","data":""}

感谢

  1. gf 框架 https://github.com/gogf/gf

转自 https://www.oschina.net/news/107367/gtoken-1-1-0-released

分享到:更多 ()