您现在的位置是:首页 > 文章详情

gtoken v1.3.9 发布,基于GF框架的toke插件

日期:2019-12-20点击:421

本次更新:

1. gf升级为V1.10.1,适配时间格式兼容性修改

上次更新:

加入多端登录支持,可配置剔除登录用户还是同时登录

介绍

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

  1. 支持单机gcache和集群gredis模式;
 # 配置文件 [gtoken] # 缓存模式 1 gcache 2 gredis cache-mode = 1 # 是否支持多端登录 multi-login = true 
  1. 支持简单token认证
  2. 加入缓存自动续期功能
 // 注:通过MaxRefresh,默认当用户第五天访问时,自动再进行五天续期 // 超时时间 默认10天 Timeout int // 缓存刷新时间 默认为超时时间的一半 MaxRefresh int 
  1. 框架使用简单,只需要设置登录验证方法以及登录、登出、拦截路径即可;

安装教程

  • 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/112209/gtoken-1-3-9-released
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章