在 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中文网其他相关文章!