歡迎您光臨本站 註冊首頁

gtoken v1.2.0 發布,gf 的 token 插件,支持 token 續約

←手機掃碼閱讀     admin @ 2019-06-17 , reply:0

gtoken

此版本主要加入了token續約功能並對緩存進行了優化,自此gtoken已完全可以支撐線上token認證,並支持集群模式;

介紹

基於gf框架的token插件,通過服務端驗證方式實現token認證;

  1. 支持單機gcache和集群gredis模式;

# 配置文件
# 緩存模式 1 gcache 2 gredis
cache-mode = 2
  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

[admin ]

來源:OsChina
連結:https://www.oschina.net/news/107496/gtoken-1-2-0-released
gtoken v1.2.0 發布,gf 的 token 插件,支持 token 續約已經有261次圍觀

http://coctec.com/news/all/show-post-207406.html