首页 >后端开发 >Golang >如何在 Go 1.5 中封送 PKCS8 私钥?

如何在 Go 1.5 中封送 PKCS8 私钥?

DDD
DDD原创
2024-10-26 16:03:30339浏览

How Can I Marshal PKCS8 Private Keys in Go 1.5?

在 Go 中编组 PKCS8 私钥

出现了关于在 Go 1.5 中编组 PKCS8 私钥的方法的可用性的问题。类似的函数,例如 x509.MarshalPKCS1PrivateKey,受到追捧。

自定义解决方案

有趣的是,Go 中没有用于编组 PKCS8 私钥的标准函数。不过,下面提供了一个自定义解决方案:

<code class="go">type pkcs8Key struct {
    Version             int
    PrivateKeyAlgorithm []asn1.ObjectIdentifier
    PrivateKey          []byte
}

func rsa2pkcs8(key *rsa.PrivateKey) ([]byte, error) {
    var pkey pkcs8Key
    pkey.Version = 0
    pkey.PrivateKeyAlgorithm = make([]asn1.ObjectIdentifier, 1)
    pkey.PrivateKeyAlgorithm[0] = asn1.ObjectIdentifier{1, 2, 840, 113549, 1, 1, 1}
    pkey.PrivateKey = x509.MarshalPKCS1PrivateKey(key)

    return asn1.Marshal(pkey)
}</code>

这个自定义函数 rsa2pkcs8 可用于在 Go 1.5 中编组 PKCS8 私钥。

以上是如何在 Go 1.5 中封送 PKCS8 私钥?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn