go jwt 使用

import (
	"errors"
	"github.com/dgrijalva/jwt-go"
	"math/rand"
	"strings"
)

var TokenMalformedErr = errors.New("token malformed error")
var TokenExpiredErr = errors.New("token expired")
var TokenNotValidYetErr = errors.New("token not valid yet")
var TokenInvalidErr = errors.New("token invalid")

const SaltSource string = "adcdefghjkmnpqrstuvwxyz1234567890ABCDEFGHJKLMNPQRSTUVWXYZ9876543210"

var SignKey = "sadaWW23FD"

var slen = len(SaltSource)

func RandGenSalt() string {
	builder := strings.Builder{}
	for i := 0; i < 4; i++ {
		intn := rand.Intn(slen)
		builder.WriteByte(SaltSource[intn])
	}
	return builder.String()
}

func init() {
	rand.Seed(time.Now().UnixNano())
}

//认证对象
type Certification struct {
	jwt.StandardClaims
    // 自定义字段,添加自己需要的信息
	Openid string
	UserId int
	//盐,随机数
	Salt string
}

func GenToken(claim Certification) (string, error) {
	claim.Salt = RandGenSalt()
	token := jwt.NewWithClaims(jwt.SigningMethodHS256, claim)
	return token.SignedString([]byte(SignKey))
}

func ParseToken(token string) (*Certification, error) {
	parse, err := jwt.ParseWithClaims(token, &Certification{}, keyFunc)
	if err != nil {
		if ve, ok := err.(*jwt.ValidationError); ok {
			e := ve.Errors
			if e&jwt.ValidationErrorMalformed != 0 {
				return nil, TokenMalformedErr
			} else if e&jwt.ValidationErrorExpired != 0 {
				return nil, TokenExpiredErr
			} else if e&jwt.ValidationErrorNotValidYet != 0 {
				return nil, TokenNotValidYetErr
			} else {
				return nil, TokenInvalidErr
			}
		}
		return nil, TokenInvalidErr
	}
	if claims, ok := parse.Claims.(*Certification); ok && parse.Valid {
		return claims, nil
	}
	return nil, TokenInvalidErr
}

func keyFunc(_ *jwt.Token) (interface{}, error) {
	return []byte(SignKey), nil
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值