登录
首页 >  Golang >  Go问答

生成 JWT 令牌时如何处理无效密钥类型错误

来源:stackoverflow

时间:2024-03-13 18:57:29 176浏览 收藏

哈喽!大家好,很高兴又见面了,我是golang学习网的一名作者,今天由我给大家带来一篇《生成 JWT 令牌时如何处理无效密钥类型错误》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!

问题内容

我遇到了这个问题,真的不知道如何解决,有人可以帮忙提供一个可行的解决方案吗?

func GenerateJWT(name, role string) (string, error)  {
    //create a singner for rsa 256
    claims := &jwt.StandardClaims{
        ExpiresAt: 15000,
        Issuer:    "test",
    }

    token :=jwt.NewWithClaims(jwt.SigningMethodES256, claims)
    log.Println("generated toke is ")
    log.Println(token)
    tokenString, err := token.SignedString([]byte("secret"))
....
}

现在我总是有:

键的类型无效

错误。我用谷歌搜索了很多,甚至对于 jwt-go 库本身,他们也提供了完全相同的解决方案,但为什么我一直有

键的类型无效

错误?

任何人都可以帮助提供有关如何在 go 中生成 jwt 令牌的工作示例吗?


解决方案


来自README

ecdsa 签名方法(es256、es384、es512)需要 *ecdsa.privatekey 进行签名,*ecdsa.publickey 进行验证

所以使用椭圆曲线键:

package main

import (
        "crypto/ecdsa"
        "crypto/elliptic"
        "crypto/rand"
        "log"

        jwt "github.com/dgrijalva/jwt-go"
)

func main() {
        key, err := ecdsa.generatekey(elliptic.p256(), rand.reader)
        if err != nil {
                log.fatal(err)
        }

        claims := &jwt.standardclaims{
                expiresat: 15000,
                issuer:    "test",
        }

        token := jwt.newwithclaims(jwt.signingmethodes256, claims)

        tokenstring, err := token.signedstring(key)
        if err != nil {
                log.fatal(err)
        }

        log.println(tokenstring)
}

存储生成的密钥以供以后与 jwt.parseecprivatekeyfrompem 和 jwt.parseecpublickeyfrompem 一起使用:

import (
        "crypto/ecdsa"
        "crypto/x509"
        "encoding/pem"
)

func pemKeyPair(key *ecdsa.PrivateKey) (privKeyPEM []byte, pubKeyPEM []byte, err error) {
        der, err := x509.MarshalECPrivateKey(key)
        if err != nil {
                return nil, nil, err
        }

        privKeyPEM = pem.EncodeToMemory(&pem.Block{
                Type:  "EC PRIVATE KEY",
                Bytes: der,
        })

        der, err = x509.MarshalPKIXPublicKey(key.Public())
        if err != nil {
                return nil, nil, err
        }

        pubKeyPEM = pem.EncodeToMemory(&pem.Block{
                Type:  "EC PUBLIC KEY",
                Bytes: der,
        })

        return
}

今天关于《生成 JWT 令牌时如何处理无效密钥类型错误》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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