jwt.go 1.78 KB
Newer Older
chenweijian's avatar
chenweijian committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
package user_s

import (
	"github.com/dgrijalva/jwt-go"
	"hilo-user/myerr"
	"hilo-user/myerr/bizerr"
	"hilo-user/resource/config"
	"hilo-user/resource/mysql"
	"time"
)

// 载荷,增加用户别名
type Claims struct {
	UserId     uint64
	ExternalId string
	jwt.StandardClaims
}

// 生成App用的jwt token
// issuer 外面传
func generateGameJwtToken(userId uint64, externalId string, issuer string) (string, error) {
	jwtConfig := config.GetConfigGameJWT()
	duration, err := time.ParseDuration(jwtConfig.EXPIRE)
	if err != nil {
		return "", myerr.WrapErr(err)
	}

	expireTime := time.Now().Add(duration)
	claims := Claims{
		UserId:     userId,
		ExternalId: externalId,
		StandardClaims: jwt.StandardClaims{
			ExpiresAt: expireTime.UnixNano() / 1e6, //过期时间
			Issuer:    issuer,                      //签名的发行者
		},
	}
	tokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
	token, err := tokenClaims.SignedString(getGameJWTSecret())
	return token, myerr.WrapErr(err)
}

//解析jwt token
func ParseJwtToken(token, issuer string) (userId mysql.ID, externalId string, expiresAt int64, err error) {
	tokenClaims, err := jwt.ParseWithClaims(token, &Claims{}, func(token *jwt.Token) (interface{}, error) {
		return getGameJWTSecret(), nil
	})
	if err != nil {
		return
	}
	if tokenClaims != nil {
		claims, ok := tokenClaims.Claims.(*Claims)
		if ok && tokenClaims.Valid {
			if time.Now().Unix() > claims.ExpiresAt {
				err = bizerr.GameTokenExpire
				return
			}
			if claims.Issuer != issuer {
				err = bizerr.GameTokenInvalid
				return
			}
			// success
			userId, externalId, expiresAt = claims.UserId, claims.ExternalId, claims.ExpiresAt
		}
	} else {
		err = bizerr.GameTokenInvalid
	}
	return
}

func getGameJWTSecret() []byte {
	return []byte(config.GetConfigGameJWT().SECRET)
}