go 实现 jwt 签名和验证

变化

上古时代的开发方式,都是通过COOKIE来认证。现在是使用JWT header 来认证。
golang中很方便自带的签发jwt的token。最新使用的库是

go get -u github.com/golang-jwt/jwt/v4

注意
很多老人都在使用github.com/dgrijalva/jwt-go,而这个实际上已经不维护和更新了。
现在都转交给官方去维护了,官方说明 https://github.com/golang-jwt/jwt/blob/main/MIGRATION_GUIDE.md

签发

var (
	secKey = "123455" // 签发秘钥
	jwt string 
	err error
)
t := jwt.NewWithClaims(jwt.SigningMethodHS256, jwt.RegisteredClaims{
	Issuer:    "my server",
	IssuedAt:  jwt.NewNumericDate(time.Now()),
	ExpiresAt: jwt.NewNumericDate(time.Now().AddDate(0, 0, 7)),
})

jwt, err = t.SignedString([]byte(secKey))

验证解码

var data jwt.RegisteredClaims
var secKey = "123455" // 密码
token, err := jwt.ParseWithClaims(resp.Jwt, &data, func(token *jwt.Token) (interface{}, error) {
	return []byte(secKey), nil
})
fmt.Println("token = ", token, err, data)

当然,秘钥觉得简单,你可以生成RSA的,但过程会很耗时。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值