gtoken- 基于 gf 框架的 token 插件

网友投稿 1171 2022-10-21

gtoken- 基于 gf 框架的 token 插件

gtoken- 基于 gf 框架的 token 插件

介绍

基于gf框架的token插件,通过服务端验证方式实现token认证;已完全可以支撑线上token认证,并支持集群模式;使用简单,大家可以放心使用;

1. 支持单机gcache和集群gredis模式;

# 配置文件[gtoken] # 缓存模式 1 gcache 2 gredis cache-mode = 1 # 是否支持多端登录 multi-login = true

2. 支持简单token认证

3. 加入缓存自动续期功能

// 注:通过MaxRefresh,默认当用户第五天访问时,自动再进行五天续期// 超时时间 默认10天Timeout int// 缓存刷新时间 默认为超时时间的一半MaxRefresh int

4. 框架使用简单,只需要设置登录验证方法以及登录、登出、拦截路径即可;

github地址:https://github.com/goflyfox/gtokengitee地址:https://gitee.com/goflyfox/gtoken

gtoken优势

有效的避免了jwt服务端无法退出问题;可以解决jwt无法作废已颁布的令牌;用户扩展信息仍存储在服务端,可有效的减少传输空间;gtoken支撑单点应用使用内存存储,也支持集群使用redis存储;支持缓存自动续期,并且不需要客户端进行实现;

安装教程

gopath模式: go get https://github.comgoflyfox/gtoken或者 使用go.mod添加 :require github.comgoflyfox/gtoken last

使用说明

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

// 启动gtoken gtoken := >oken.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进行测试并查看结果;验证逻辑说明:

访问用户信息,提示未携带token登录后,携带token访问正常登出成功携带之前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”:”“}

感谢

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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:翻转单词顺序列
下一篇:Gin 框架的文件上传组件
相关文章

 发表评论

暂时没有评论,来抢沙发吧~