为了账号安全,请及时绑定邮箱和手机立即绑定

在 jwt-go 中解析 JWT Auth 令牌时,密钥的类型无效

在 jwt-go 中解析 JWT Auth 令牌时,密钥的类型无效

Go
喵喵时光机 2023-07-17 09:50:52
我正在 GoLang API 中设置安全中间件,似乎所有设置都正确,但我收到错误“密钥类型无效”。我已确认我的签名算法是 RS256 并且中间件选项已配置 @SigningMethod: jwt.SigningMethodRS256我有一个有效的令牌……中间件中的其他所有内容都会通过。中间件中此错误的入口点是 jwt.ParseRSAPrivateKeyFromPEM 方法。我已将错误隔离在包 github.com/dgrijalva/jwt-go/rsa.go 中,Verify() on line :62 是抛出的 ErrInvalidKeyType。到目前为止,所有参数似乎都是可靠且适当的(例如 m|signingString|signature|key),但是这个 key.(*rsa.PublicKey) 失败了......在我的调试器(GoLand)中,我检查 *rsa 并得到响应“找不到 rsa 的符号值”...if rsaKey, ok = key.(*rsa.PublicKey); !ok {     return ErrInvalidKeyType }请注意……如果还不是太明显的话……我对 GoLang 很菜鸟- - - 更新 - - -因此,在最细粒度的级别上,恐慌从 go/1.12.8/libexec/src/crypto/rsa/rsa.go:49 开始func (pub *PublicKey) Size() int {     log.Printf("SIZE ::: %v :: %v",pub.N.BitLen(), pub.N)         return (pub.N.BitLen() + 7) / 8         }pub 被视为零指针取消引用。我追溯到 mux -->加密/rsa.VerifyPKCS1v15(...) /usr/local/Cellar/go/1.12.8/libexec/src/crypto/rsa/pkcs1v15.go:275github.com/dgrijalva/jwt-go.(*SigningMethodRSA).Verify(...) /Users/me/Sandbox/src/github.com/dgrijalva/jwt-go/rsa.go:73github.com/dgrijalva/jwt-go.(*Parser).ParseWithClaims(...) /Users/me/Sandbox/src/github.com/dgrijalva/jwt-go/parser.go:77github.com/dgrijalva/jwt-go.(*Parser).Parse(...) /Users/btschirhart/Sandbox/src/github.com/dgrijalva/jwt-go/parser.go:20github.com/dgrijalva/jwt-go.Parse(...) /Users/me/Sandbox/src/github.com/dgrijalva/jwt-go/token.go:89github.com/auth0/go-jwt-middleware.(*JWTMiddleware).CheckJWT(...) /Users/me/Sandbox/src/github.com/auth0/go-jwt-middleware/jwtmiddleware.go:203github.com/auth0/go-jwt-middleware.(*JWTMiddleware).Handler.func1(...) /Users/me/Sandbox/src/github.com/auth0/go-jwt-middleware/jwtmiddleware.go:110net/http.HandlerFunc.ServeHTTP(...) /usr/local/Cellar/go/1.12.8/libexec/src/net/http/server.go:1995github.com/gorilla/mux.(*Router).ServeHTTP(...) /Users/me/Sandbox/src/github.com/gorilla/mux/mux.go:210 +0xe3
查看完整描述

1 回答

?
拉丁的传说

TA贡献1789条经验 获得超8个赞

找到了答案。这不是一个真正的答案,但它确实解决了问题。


我使用“----BEGIN”和“END----”而不是“-----BEGIN”和“END-----”在中间件中构建证书。


在 go/1.12.8/libexec/src/encoding/pem/pem.go:82 中,对 '-----BEGIN' 进行检查,如果失败,则仅返回 nil。


if bytes.HasPrefix(data, pemStart[1:]) {

    rest = rest[len(pemStart)-1 : len(data)]

} else if i := bytes.Index(data, pemStart); i >= 0 {

    rest = rest[i+len(pemStart) : len(data)]

} else {

    return nil, data

}


查看完整回答
反对 回复 2023-07-17
  • 1 回答
  • 0 关注
  • 105 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信