gpt4 book ai didi

ssl - 从私钥中提取公钥

转载 作者:IT王子 更新时间:2023-10-29 01:56:41 26 4
gpt4 key购买 nike

我试图通过以下方式以编程方式完成步骤 (2):

1. openssl genrsa -out signing.pem 2048
2. openssl rsa -in signing.pem -outform PEM -pubout -out signing.pub.pem

下面是一个简单的函数,它读取私钥并尝试提取公钥。

但是,我在匹配第 2 步时遇到困难,因为以编程方式生成的公钥不同于基于 openssl CLI 的公钥,我确定一定有错误,请帮助我。

谢谢

   func main() {
priv, err := ioutil.ReadFile("signing.pem")

block, _ := pem.Decode([]byte(priv))
if block == nil || block.Type != "RSA PRIVATE KEY" {
log.Fatal("failed to decode PEM block containing public key")
}
key, err := x509.ParsePKCS1PrivateKey(block.Bytes)
if err != nil {
log.Fatal(err)
}

publicKeyDer := x509.MarshalPKCS1PublicKey(&pub.PublicKey)
pubKeyBlock := pem.Block{
Type: "PUBLIC KEY",
Headers: nil,
Bytes: publicKeyDer,
}
pubKeyPem := string(pem.EncodeToMemory(&pubKeyBlock))
fmt.Println(pubKeyPem)
}

以防万一有人想检查代码并尝试一下,这里是链接:

https://play.golang.org/p/rKerkh-31KI

最佳答案

使用MarshalPKIXPublicKey

publicKeyDer, err := x509.MarshalPKIXPublicKey(&key.PublicKey)
if err != nil {
log.Fatal(err)
}

代替

publicKeyDer := x509.MarshalPKCS1PublicKey(&key.PublicKey)

Playground

关于ssl - 从私钥中提取公钥,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53221108/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com