mirror of
https://github.com/lzh-1625/go_process_manager.git
synced 2025-10-05 16:06:51 +08:00
edit token check
This commit is contained in:
@@ -1,7 +1,6 @@
|
|||||||
package middle
|
package middle
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
|
||||||
"slices"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
@@ -46,36 +45,19 @@ func CheckToken() gin.HandlerFunc {
|
|||||||
return strings.HasPrefix(c.Request.URL.Path, s)
|
return strings.HasPrefix(c.Request.URL.Path, s)
|
||||||
}) {
|
}) {
|
||||||
var token string
|
var token string
|
||||||
if c.Request.Header.Get("token") != "" {
|
if c.Request.Header.Get("Authorization") != "" {
|
||||||
token = c.Request.Header.Get("token")
|
token = strings.TrimPrefix(c.Request.Header.Get("Authorization"), "bearer ")
|
||||||
} else {
|
} else {
|
||||||
token = c.Query("token")
|
token = c.Query("token")
|
||||||
}
|
}
|
||||||
if _, err := utils.VerifyToken(token); err != nil {
|
if mc, err := utils.VerifyToken(token); err != nil {
|
||||||
rErr(c, -2, "token校验失败", err)
|
rErr(c, -2, "token校验失败", err)
|
||||||
return
|
return
|
||||||
}
|
|
||||||
if username, err := getUser(c); err != nil {
|
|
||||||
rErr(c, -1, "无法获取user信息", err)
|
|
||||||
} else {
|
} else {
|
||||||
c.Set(eum.CtxUserName, username)
|
c.Set(eum.CtxUserName, mc.Username)
|
||||||
c.Set(eum.CtxRole, repository.UserRepository.GetUserByName(username).Role)
|
c.Set(eum.CtxRole, repository.UserRepository.GetUserByName(mc.Username).Role)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
c.Next()
|
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)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Reference in New Issue
Block a user