修改 LoginStatus 用 context 传递

This commit is contained in:
bjdgyc 2024-11-12 15:11:28 +08:00
parent 9ef29545bc
commit 2b757b65b6
3 changed files with 31 additions and 9 deletions

View File

@ -1,6 +1,7 @@
package handler package handler
import ( import (
"context"
"encoding/xml" "encoding/xml"
"io" "io"
"net" "net"
@ -16,15 +17,24 @@ var lockManager = admin.GetLockManager()
const loginStatusKey = "login_status" const loginStatusKey = "login_status"
type HttpContext struct {
LoginStatus bool // 登录状态
}
// 防爆破中间件 // 防爆破中间件
func antiBruteForce(next http.Handler) http.Handler { func antiBruteForce(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { return http.HandlerFunc(func(w http.ResponseWriter, old_r *http.Request) {
// 防爆破功能全局开关 // 防爆破功能全局开关
if !base.Cfg.AntiBruteForce { if !base.Cfg.AntiBruteForce {
next.ServeHTTP(w, r) next.ServeHTTP(w, old_r)
return return
} }
// 非并发安全
hc := &HttpContext{}
ctx := context.WithValue(context.Background(), loginStatusKey, hc)
r := old_r.WithContext(ctx)
body, err := io.ReadAll(r.Body) body, err := io.ReadAll(r.Body)
if err != nil { if err != nil {
http.Error(w, "Failed to read request body", http.StatusBadRequest) http.Error(w, "Failed to read request body", http.StatusBadRequest)
@ -96,8 +106,10 @@ func antiBruteForce(next http.Handler) http.Handler {
next.ServeHTTP(w, r) next.ServeHTTP(w, r)
// 检查登录状态 // 检查登录状态
Status, _ := lockManager.LoginStatus.Load(loginStatusKey) // Status, _ := lockManager.LoginStatus.Load(loginStatusKey)
loginStatus, _ := Status.(bool) // loginStatus, _ := Status.(bool)
loginStatus := hc.LoginStatus
// 更新用户登录状态 // 更新用户登录状态
lockManager.UpdateGlobalIPLock(ip, now, loginStatus) lockManager.UpdateGlobalIPLock(ip, now, loginStatus)
@ -105,6 +117,6 @@ func antiBruteForce(next http.Handler) http.Handler {
lockManager.UpdateUserIPLock(username, ip, now, loginStatus) lockManager.UpdateUserIPLock(username, ip, now, loginStatus)
// 清除登录状态 // 清除登录状态
lockManager.LoginStatus.Delete(loginStatusKey) // lockManager.LoginStatus.Delete(loginStatusKey)
}) })
} }

View File

@ -94,7 +94,10 @@ func LinkAuth(w http.ResponseWriter, r *http.Request) {
// TODO 用户密码校验 // TODO 用户密码校验
err = dbdata.CheckUser(cr.Auth.Username, cr.Auth.Password, cr.GroupSelect) err = dbdata.CheckUser(cr.Auth.Username, cr.Auth.Password, cr.GroupSelect)
if err != nil { if err != nil {
lockManager.LoginStatus.Store(loginStatusKey, false) // 记录登录失败状态 // lockManager.LoginStatus.Store(loginStatusKey, false) // 记录登录失败状态
hc := r.Context().Value(loginStatusKey).(*HttpContext)
hc.LoginStatus = false
base.Warn(err, r.RemoteAddr) base.Warn(err, r.RemoteAddr)
ua.Info = err.Error() ua.Info = err.Error()
ua.Status = dbdata.UserAuthFail ua.Status = dbdata.UserAuthFail
@ -119,7 +122,10 @@ func LinkAuth(w http.ResponseWriter, r *http.Request) {
} }
// 用户otp验证 // 用户otp验证
if base.Cfg.AuthAloneOtp && !v.DisableOtp { if base.Cfg.AuthAloneOtp && !v.DisableOtp {
lockManager.LoginStatus.Store(loginStatusKey, true) // 重置OTP验证计数 // lockManager.LoginStatus.Store(loginStatusKey, true) // 重置OTP验证计数
hc := r.Context().Value(loginStatusKey).(*HttpContext)
hc.LoginStatus = true
sessionID, err := GenerateSessionID() sessionID, err := GenerateSessionID()
if err != nil { if err != nil {
base.Error("Failed to generate session ID: ", err) base.Error("Failed to generate session ID: ", err)

View File

@ -109,7 +109,9 @@ func DeleteCookie(w http.ResponseWriter, name string) {
http.SetCookie(w, cookie) http.SetCookie(w, cookie)
} }
func CreateSession(w http.ResponseWriter, r *http.Request, authSession *AuthSession) { func CreateSession(w http.ResponseWriter, r *http.Request, authSession *AuthSession) {
lockManager.LoginStatus.Store(loginStatusKey, true) // 更新登录成功状态 // lockManager.LoginStatus.Store(loginStatusKey, true) // 更新登录成功状态
hc := r.Context().Value(loginStatusKey).(*HttpContext)
hc.LoginStatus = true
cr := authSession.ClientRequest cr := authSession.ClientRequest
ua := authSession.UserActLog ua := authSession.UserActLog
@ -201,7 +203,9 @@ func LinkAuth_otp(w http.ResponseWriter, r *http.Request) {
// http.Error(w, "TooManyError, please login again", http.StatusBadRequest) // http.Error(w, "TooManyError, please login again", http.StatusBadRequest)
// return // return
// } // }
lockManager.LoginStatus.Store(loginStatusKey, false) // 记录登录失败状态 // lockManager.LoginStatus.Store(loginStatusKey, false) // 记录登录失败状态
hc := r.Context().Value(loginStatusKey).(*HttpContext)
hc.LoginStatus = false
base.Warn("OTP 动态码错误", username, r.RemoteAddr) base.Warn("OTP 动态码错误", username, r.RemoteAddr)
ua.Info = "OTP 动态码错误" ua.Info = "OTP 动态码错误"