代码拉取完成,页面将自动刷新
package jwt
import (
"fmt"
"gitee.com/xlizy/common-go/base/common_const"
gJwt "github.com/golang-jwt/jwt/v4"
"time"
)
const (
defaultKey = "EcALispjpvf4JrsucfmNtOGQkSni6kDU08aYLfmRHoCXn6M93Nj3wJMSxv2H3E0TvF85oVnpDKswtuFR1R8UF7rXzRe8SMoZv93XPqZCcM0I8ZpnDLZRCKBbz9NOgpCA"
)
type Payload struct {
IdMask string
Roles []string
Expire string
}
type PayloadClaims struct {
Payload Payload
gJwt.RegisteredClaims
}
func GenJwt(payload Payload, key string) string {
if key == "" {
key = defaultKey
}
if payload.Expire == "" {
payload.Expire = time.Now().Add(24 * time.Hour).Format(common_const.DataFormat)
}
// 创建Token结构体
claims := gJwt.NewWithClaims(gJwt.SigningMethodHS256, PayloadClaims{
Payload: payload,
})
// 调用加密方法,生成Token字符串
signingString, err := claims.SignedString([]byte(key))
if err != nil {
fmt.Println(err.Error())
}
return signingString
}
func GetPayload(signingString, key string) (*Payload, error) {
if key == "" {
key = defaultKey
}
// 根据Token字符串解析成Claims结构体
claims, err := gJwt.ParseWithClaims(signingString, &PayloadClaims{}, func(token *gJwt.Token) (interface{}, error) {
return []byte(key), nil
})
if err != nil {
return nil, err
}
return &claims.Claims.(*PayloadClaims).Payload, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。