edit token check

This commit is contained in:
akrike
2025-09-03 22:06:30 +08:00
parent 2e37eae3ca
commit e14df1fd99

View File

@@ -1,7 +1,6 @@
package middle
import (
"errors"
"slices"
"strings"
@@ -46,36 +45,19 @@ func CheckToken() gin.HandlerFunc {
return strings.HasPrefix(c.Request.URL.Path, s)
}) {
var token string
if c.Request.Header.Get("token") != "" {
token = c.Request.Header.Get("token")
if c.Request.Header.Get("Authorization") != "" {
token = strings.TrimPrefix(c.Request.Header.Get("Authorization"), "bearer ")
} else {
token = c.Query("token")
}
if _, err := utils.VerifyToken(token); err != nil {
if mc, err := utils.VerifyToken(token); err != nil {
rErr(c, -2, "token校验失败", err)
return
}
if username, err := getUser(c); err != nil {
rErr(c, -1, "无法获取user信息", err)
} else {
c.Set(eum.CtxUserName, username)
c.Set(eum.CtxRole, repository.UserRepository.GetUserByName(username).Role)
c.Set(eum.CtxUserName, mc.Username)
c.Set(eum.CtxRole, repository.UserRepository.GetUserByName(mc.Username).Role)
}
}
c.Next()
}
}
func getUser(ctx *gin.Context) (string, error) {
var token string
if ctx.Request.Header.Get("token") != "" {
token = ctx.Request.Header.Get("token")
} else {
token = ctx.Query("token")
}
if mc, err := utils.VerifyToken(token); err == nil && mc != nil {
return mc.Username, nil
} else {
return "", errors.Join(errors.New("用户信息获取失败"), err)
}
}