代码拉取完成,页面将自动刷新
package utils
import (
"Project/global"
"Project/model/common/request"
"errors"
"time"
"github.com/dgrijalva/jwt-go"
)
type JWT struct {
SigningKey []byte
}
func NewJWT() *JWT {
return &JWT{
[]byte(global.KBB_CONFIG.JWT.Header),
}
}
type MyClaims struct {
LibraryId int64 `json:"library_id"`
UserID int64 `json:"user_id"`
jwt.StandardClaims
}
// GenToken 生成JWT
func (j *JWT) GenToken(middleInfo request.MiddleInfo) (string, error) {
// 创建一个我们自己的声明
c := MyClaims{
middleInfo.LibraryId.LibraryId,
middleInfo.UserInfo.Id,
jwt.StandardClaims{
ExpiresAt: time.Now().Add(time.Duration(global.KBB_CONFIG.JWT.Timeout) * time.Second * 18).Unix(), // 过期时间
Issuer: "my-project", // 签发人
},
}
// 使用指定的签名方法创建签名对象
token := jwt.NewWithClaims(jwt.SigningMethodHS256, c)
// 使用指定的secret签名并获得完整的编码后的字符串token
return token.SignedString([]byte(global.KBB_CONFIG.JWT.Secret))
}
// ParseToken 解析JWT
func (j *JWT) ParseToken(tokenString string) (*MyClaims, error) {
// 解析token
var mc = new(MyClaims)
token, err := jwt.ParseWithClaims(tokenString, mc, func(token *jwt.Token) (i interface{}, err error) {
return []byte(global.KBB_CONFIG.JWT.Secret), nil
})
if err != nil {
return nil, err
}
if token.Valid { // 校验token
return mc, nil
}
return nil, errors.New("invalid token")
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。