refactor: token authentication

This commit is contained in:
zchengo
2022-12-11 20:02:19 +08:00
parent b16d31189f
commit cf816b3f52
5 changed files with 33 additions and 23 deletions
+22 -11
View File
@@ -2,25 +2,36 @@ package common
import (
"crm/global"
"strconv"
"time"
"github.com/golang-jwt/jwt/v4"
)
var signingKey = []byte(global.Config.Jwt.SigningKey)
type Claims struct {
Uid int64 `json:"uid"`
jwt.RegisteredClaims
}
// 生成Token
func GenToken(uid int64, expire int64) (string, error) {
username := strconv.FormatInt(uid, 20)
type Claims struct {
Username string `json:"username"`
jwt.RegisteredClaims
}
claims := Claims{username, jwt.RegisteredClaims{
ExpiresAt: &jwt.NumericDate{Time: time.Now().Add(time.Duration(expire) * time.Hour)},
Issuer: username,
func GenToken(uid int64) (string, error) {
var signingKey = []byte(global.Config.Jwt.SigningKey)
var expiredTime = global.Config.Jwt.ExpiredTime
claims := Claims{uid, jwt.RegisteredClaims{
ExpiresAt: &jwt.NumericDate{Time: time.Now().Add(time.Duration(expiredTime) * time.Second)},
Issuer: "crm",
}}
token, err := jwt.NewWithClaims(jwt.SigningMethodHS256, claims).SignedString(signingKey)
return token, err
}
// 校验Token
func VerifyToken(tokens string) (int64, error) {
token, err := jwt.ParseWithClaims(tokens, &Claims{}, func(token *jwt.Token) (interface{}, error) {
return []byte(global.Config.Jwt.SigningKey), nil
})
claims, ok := token.Claims.(*Claims)
if ok && token.Valid {
return claims.Uid, nil
}
return 0, err
}