在 Go 中编组 PKCS8 私钥
Go 1.5 缺乏编组 PKCS8 私钥的标准函数。但是,我们可以利用自定义解决方案。
为了编组 PKCS8 密钥,我们定义一个表示 PKCS8 格式的自定义结构 pkcs8Key。它包括版本、私钥算法和实际私钥字节的字段。
对于 RSA 密钥,我们使用 rsa2pkcs8 函数将其转换为 PKCS8 格式。此函数将版本设置为 0,分配适当的私钥算法 OID,并封送 PKCS1 格式的私钥。
<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>
此自定义解决方案允许我们以编程方式封送 PKCS8 私钥,即使 Go 缺乏用于此目的的官方函数。
以上是如何在 Go 1.5 中编组 PKCS8 私钥?的详细内容。更多信息请关注PHP中文网其他相关文章!