我从第一个证书中获取:https://www.googleapis.com/oauth2/v2/certs 'n' 和 'e' 键值。 Go中是否有一个包可以用'n'和'e'构建公钥?我不知道使用 crypto/rsa 包是如何完成的。一些代码将是宝贵的。谢谢。
最佳答案
rsa 包有一个 PublicKey
键入字段 N
和 E
。按照 JWA draft 中的描述解码部分应该非常简单。 .
这是一些快速破解的代码(Playground):
package main
import (
"bytes"
"crypto/rsa"
"encoding/base64"
"encoding/binary"
"fmt"
"math/big"
)
func main() {
nStr := "AN+7p8kw1A3LXfAJi+Ui4o8F8G0EeB4B5RuufglWa4AkadDaLTxGLNtY/NtyRZBfwhdAmRjKQJTVgn5j3y0s+j/bvpzMktoVeHB7irOhxDnZJdIxNNMY3nUKBgQB81jg8lNTeBrJqELSJiRXQIe5PyWJWwQJ1XrtfQNcwGkICM1L"
decN, err := base64.StdEncoding.DecodeString(nStr)
if err != nil {
fmt.Println(err)
return
}
n := big.NewInt(0)
n.SetBytes(decN)
eStr := "AQAB"
decE, err := base64.StdEncoding.DecodeString(eStr)
if err != nil {
fmt.Println(err)
return
}
var eBytes []byte
if len(decE) < 8 {
eBytes = make([]byte, 8-len(decE), 8)
eBytes = append(eBytes, decE...)
} else {
eBytes = decE
}
eReader := bytes.NewReader(eBytes)
var e uint64
err = binary.Read(eReader, binary.BigEndian, &e)
if err != nil {
fmt.Println(err)
return
}
pKey := rsa.PublicKey{N: n, E: int(e)}
}
关于json - 从 Golang 中的模数和指数创建公钥,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25179492/