golang生成RSA公钥和密钥
在Go语言中,可以使用crypto/rsa
标准库来生成RSA公钥和私钥。以下是生成RSA密钥对的示例代码:
package main
import (
"crypto/rand"
"crypto/rsa"
"crypto/x509"
"encoding/pem"
"log"
"os"
)
func main() {
// 生成RSA私钥
privateKey, err := rsa.GenerateKey(rand.Reader, 2048)
if err != nil {
log.Fatalf("生成RSA私钥失败: %v", err)
}
// 编码为PEM格式
privateKeyPEM := &pem.Block{
Type: "RSA PRIVATE KEY",
Bytes: x509.MarshalPKCS1PrivateKey(privateKey),
}
// 写入私钥文件
privateFile, err := os.Create("private.pem")
if err != nil {
log.Fatalf("创建私钥文件失败: %v", err)
}
defer privateFile.Close()
err = pem.Encode(privateFile, privateKeyPEM)
if err != nil {
log.Fatalf("写入私钥失败: %v", err)
}
// 生成公钥
publicKey := &privateKey.PublicKey
publicKeyPEM := &pem.Block{
Type: "PUBLIC KEY",
Bytes: x509.MarshalPKCS1PublicKey(publicKey),
}
// 写入公钥文件
publicFile, err := os.Create("public.pem")
if err != nil {
log.Fatalf("创建公钥文件失败: %v", err)
}
defer publicFile.Close()
err = pem.Encode(publicFile, publicKeyPEM)
if err != nil {
log.Fatalf("写入公钥失败: %v", err)
}
}
这段代码首先使用rsa.GenerateKey
函数生成一个2048位的RSA私钥。然后,它将私钥编码为PEM格式并保存到文件中。接着,它从私钥中提取公钥,将公钥编码为PEM格式,并保存到另一个文件中。
评论已关闭