登录
首页 >  Golang >  Go问答

在 Go 中如何提取 JWT 令牌的过期日期?

来源:stackoverflow

时间:2024-02-06 13:00:24 420浏览 收藏

本篇文章给大家分享《在 Go 中如何提取 JWT 令牌的过期日期?》,覆盖了Golang的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

问题内容

我有一个 jwt 令牌,我可以在 https://jwt.io/ 网站上看到解码后的令牌。它不需要我设置任何秘密或声明。所以我正在寻找一种方法来解码令牌以获得过期日期而不提供任何秘密。

我正在使用库 ngopkg.in/square/go-jose.v2/jwt ,下面是我的代码:

token, err := jwt.ParseSigned(jwtToken)

返回值 token 有一个标头字段,其中包括 keyid、算法,但它没有给我过期日期。

我搜索过这个主题,人们说使用 github.com/auth0/go-jwt-middleware/v2/validator 库,但它需要设置密钥/秘密。解析令牌的过期日期是否需要秘密。 网站https://jwt.io/如何知道过期日期?


正确答案


使用 jwt.io 中的示例 jwt 令牌,此代码解析并检索未经验证签名的声明:

func main() {
    raw := "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"

    t, err := jwt.ParseSigned(raw)
    if err != nil {
        panic(err)
    }

    var claims map[string]any
    if err := t.UnsafeClaimsWithoutVerification(&claims); err != nil {
        panic(err)
    }

    fmt.Println(claims)
}

在此示例中,过期时间应显示为 claims 映射中的字段之一。要检索它,请使用 exp, ok := claims["expire"] (取决于确切的名称)。

今天关于《在 Go 中如何提取 JWT 令牌的过期日期?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>