package main
import (
"fmt"
"github.com/dgrijalva/jwt-go"
"time"
)
// 定义一个Claims结构体用于存储JWT的相关信息
type CustomClaims struct {
ID int
Username string
jwt.StandardClaims
}
// 生成JWT token
func GenerateToken(id int, username string) (string, error) {
// 创建Claims
claims := CustomClaims{
id,
username,
jwt.StandardClaims{
ExpiresAt: time.Now().Add(time.Hour * 2).Unix(), // 设置过期时间
Issuer: "gin-jwt-example", // 签发者
},
}
// 创建token
token := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
// 对token进行签名
signedToken, err := token.SignedString([]byte("secret_key"))
if err != nil {
return "", err
}
return signedToken, nil
}
// 验证JWT token
func ValidateToken(tokenString string) (*CustomClaims, error) {
token, err := jwt.ParseWithClaims(tokenString, &CustomClaims{}, func(token *jwt.Token) (interface{}, error) {
return []byte("secret_key"), nil
})
if err != nil {
return nil, err
}
if claims, ok := token.Claims.(*CustomClaims); ok && token.Valid {
return claims, nil
}
return nil, fmt.Errorf("invalid token")
}
func main() {
// 生成token
tokenString, err := GenerateToken(1, "user1")
if err != nil {
panic(err)
}
fmt.Printf("Generated Token: %s\n", tokenString)
// 验证token
claims, err := ValidateToken(tokenString)
if err != nil {
panic(err)
}
fmt.Printf("Validated Token. ID: %d, Username: %s\n", claims.ID, claims.Username)
}
这段代码展示了如何在Go语言中使用jwt-go库生成和验证JWT token。首先定义了一个CustomClaims结构体来存储额外的信息,然后实现了生成和验证token的函数。最后,在main函数中演示了如何生成一个token并验证它。