🎨每次请求都重新生成token

This commit is contained in:
coward
2024-07-12 16:32:31 +08:00
parent 11d649cfc3
commit 9af89ee41f
2 changed files with 28 additions and 5 deletions

View File

@@ -1,8 +1,11 @@
package middleware
import (
"fmt"
"github.com/gin-gonic/gin"
"github.com/google/uuid"
"strings"
"time"
"wireguard-ui/component"
"wireguard-ui/global/constant"
"wireguard-ui/http/response"
@@ -59,6 +62,18 @@ func Authorization() gin.HandlerFunc {
// 将用户信息放入上下文
c.Set("user", &user)
// 生成一个新token
secret := component.JWT().GenerateSecret(user.Password, uuid.NewString(), time.Now().Local().String())
tokenStr, _, err := component.JWT().GenerateToken(user.Id, secret, userClaims.ExpiresAt.Time, userClaims.IssuedAt.Time)
if err != nil {
response.R(c).AuthorizationFailed("校验失败")
c.Abort()
return
}
c.Writer.Header().Set("Authorization", fmt.Sprintf("Bearer %s", tokenStr))
c.Writer.Header().Set("X-TOKEN", secret)
c.Next()
}
}