go - 如何从 pkcs12 存储加载 x509 key 对?

标签 go ssl server x509 pkcs#12

我有一个脚本可以通过 OpenSSL 在服务器上创建 PKCS12 存储。我正在 Go 中开发 TLS/SSL 服务器,需要从创建的 PKCS12 存储加载 key 对。如何从 PCKS12 存储中提取 key 对并加载它们?

这是我的代码片段,它给我一个错误:

src/server.go:59:19: cannot use cert (type interface {}) as type []byte in argument to ioutil.WriteFile: need type assertion
src/server.go:60:19: cannot use key (type *x509.Certificate) as type []byte in argument to ioutil.WriteFile
 import "golang.org/x/crypto/pkcs12"


 // Read byte data from pkcs12 keystore
 p12_data, err := ioutil.ReadFile("../identify.p12")
 if err != nil {
     log.Fatal(err)
 }

 // Extract cert and key from pkcs keystore
 cert, key, err := pkcs12.Decode(p12_data, "123456")
    if err != nil {
        log.Println(err)
        return
    }

//Write cert and key out to filepath
ioutil.WriteFile("cert.pem", cert, 777)
ioutil.WriteFile("key.pem", key, 777)

log.SetFlags(log.Lshortfile)
cer, err := tls.LoadX509KeyPair("cert.pem", "key.pem")
if err != nil {
    log.Println(err)
    return
}

最佳答案

您不需要使用 tls 包加载 key 对,因为 pkcs12.Decode 已经这样做了。只需初始化一个类型为 tls.Certificate 的值:

p12_data, err := ioutil.ReadFile("../identify.p12")
if err != nil {
    log.Fatal(err)
}

key, cert, err := pkcs12.Decode(p12_data, "123456") // Note the order of the return values.
if err != nil {
    log.Fatal(err)
}

tlsCert := tls.Certificate{
    Certificate: [][]byte{cert.Raw},
    PrivateKey:  key.(crypto.PrivateKey),
    Leaf:        cert,
}

引用 the documentation :

This function assumes that there is only one certificate and only one private key in the pfxData; if there are more use ToPEM instead.

该文档包含一个示例,展示了如何使用 ToPEM 来初始化 tls.Certificate。

关于go - 如何从 pkcs12 存储加载 x509 key 对?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57259755/

相关文章:

go - 如何使 LiteIDE 为 *big.Int(或您的类型)显示用户友好的监视字符串?

go - 循环遍历数据库/sql sql.Rows 多次?

go - MIME 类型 (“text/plain” )不匹配(X-Content-Type-Options : nosniff)

apache - 阻止 htaccess HTTPS 转发在本地主机上运行

ssl - Nginx DataPower 2 路 TLS

Sqlboiler 仅获取所需的列

c# - 在本地和实时开发之间使用 https 支持 url 的技术

java - 如何在服务器启动时从 ServletContext 连接到同一 Tomcat 服务器上的文件

node.js - 使用 Mongoose 设置 Mongodb 安全服务器

php - LiteSpeed Web 服务器和 "error: Cannot find OpenSSL' 的库"