2022-11-28 16:38:30 +08:00
|
|
|
package common
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"crm/global"
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/golang-jwt/jwt/v4"
|
|
|
|
|
)
|
|
|
|
|
|
2022-12-11 20:02:19 +08:00
|
|
|
type Claims struct {
|
|
|
|
|
Uid int64 `json:"uid"`
|
|
|
|
|
jwt.RegisteredClaims
|
|
|
|
|
}
|
2022-11-28 16:38:30 +08:00
|
|
|
|
|
|
|
|
// 生成Token
|
2022-12-11 20:02:19 +08:00
|
|
|
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",
|
2022-11-28 16:38:30 +08:00
|
|
|
}}
|
|
|
|
|
token, err := jwt.NewWithClaims(jwt.SigningMethodHS256, claims).SignedString(signingKey)
|
|
|
|
|
return token, err
|
|
|
|
|
}
|
2022-12-11 20:02:19 +08:00
|
|
|
|
|
|
|
|
// 校验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
|
|
|
|
|
}
|