JWT GenToken&ParseToken

JWT(Json Web Token)

获取Token、解密Token

jwt.go

go 复制代码
package jwt

import (
	"errors"
	"time"

	"github.com/golang-jwt/jwt/v5"
)

var jwtSecret = []byte("secret")

type CustomClaims struct {
	Username string `json:"username"`
	jwt.RegisteredClaims
}

func GenToken(username string) (string, error) {
	claims := CustomClaims{
		Username: username,
		RegisteredClaims: jwt.RegisteredClaims{
			ExpiresAt: jwt.NewNumericDate(time.Now().Add(2 * time.Hour)), // 过期时间
			IssuedAt:  jwt.NewNumericDate(time.Now()),                    // 签发时间
			NotBefore: jwt.NewNumericDate(time.Now()),                    // 生效时间
			Issuer:    "bluebell-app",                                    // 签发人
			Subject:   "user-token",                                      // token主题
		},
	}

	token := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
	return token.SignedString(jwtSecret)
}

func ParseToken(tokenString string) (*CustomClaims, error) {
	token, err := jwt.ParseWithClaims(tokenString, &CustomClaims{}, func(token *jwt.Token) (interface{}, error) {
		if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok {
			return nil, errors.New("unexpected signing method")
		}
		return jwtSecret, nil
	})

	if err != nil {
		return nil, err
	}

	if claims, ok := token.Claims.(*CustomClaims); ok && token.Valid {
		return claims, nil
	}

	return nil, errors.New("invalid token")
}
相关推荐
一条GO21 小时前
简单的 defer 也有可能写出BUG
go
用户5805595021021 小时前
深入理解 Go defer(下):编译器与runtime视角的实现原理
后端·go
tyung1 天前
用 zhenyi-base 做一个带网页的群聊 Demo
websocket·go
AntBlack1 天前
Ant-Browser : 发布一个开源免费的指纹浏览器 ,欢迎体验
后端·架构·go
程序员爱钓鱼1 天前
Go排序核心库: sort包深度指南
后端·面试·go
ha6662 天前
golibs — Protocol & Registry 技术文档
go
程序员爱钓鱼2 天前
Go输出与格式化核心库:fmt包完整指南
后端·面试·go
程序员爱钓鱼3 天前
Go PDF处理利器: github.com/pdfcpu/pdfcpu 深度指南
后端·面试·go
江湖十年3 天前
使用 testing/synctest 测试并发代码
后端·面试·go
比特森林探险记4 天前
Go 语言依赖注入和java 区别
go