package jwt import ( "errors" "fmt" "time" "git.ouxuan.net/tommy/osmanthuswine/src/helper" "github.com/dgrijalva/jwt-go" ) type Claims struct { AccountType string AccountId int CustomerId int CustomerPid int ActivityId int AreaId int jwt.StandardClaims } func GenJwtToken(accountType string, accountId, customerId, customerPid, areaId, activityId int) (string, error) { claims := Claims{ accountType, accountId, customerId, customerPid, activityId, areaId, jwt.StandardClaims{ ExpiresAt: time.Now().Add(time.Duration(24) * time.Hour).Unix(), Id: helper.CreateUUID(), Issuer: Issuer, Subject: Subject, Audience: Audience, }, } t := jwt.NewWithClaims(jwt.SigningMethodHS256, claims) return t.SignedString([]byte(Secret)) } //const Secret = "十步杀一人,千里不留行。" const Secret = "osmanthuswine-very-secret" const Issuer = "osmanthuswine-issuer-ox" const Subject = "osmanthuswine-subject-ox" const Audience = "osmanthuswine-audience-ox" func ParseAccessToken(accessToken string) (*Claims, error) { var claims = &Claims{} token, err := jwt.ParseWithClaims(accessToken, claims, func(token *jwt.Token) (i interface{}, e error) { if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok { return nil, fmt.Errorf("unexpected signing method: %v", token.Header["alg"]) } return []byte(Secret), nil }) if token == nil { return claims, errors.New("token invalid") } if !claims.VerifyExpiresAt(time.Now().Unix(), true) { return nil, errors.New("token expired") } return claims, err }