首页 > 后端开发 > Golang > 正文

如何在 Go 1.5 中编组 PKCS8 私钥?

Mary-Kate Olsen
发布: 2024-10-26 16:41:30
原创
349 人浏览过

 How to Marshal PKCS8 Private Keys in Go 1.5?

在 Go 中编组 PKCS8 私钥

可以在 Go 1.5 中编组 PKCS8 私钥吗?具体来说,是否有类似于 PKCS8 的 x509.MarshalPKCS1PrivateKey 的方法?

解决方案:

尽管缺少用于此任务的标准函数,但可以使用自定义解决方案:

<code class="go">import (
    "crypto/rsa"
    "crypto/asn1"
    "crypto/x509"
)

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>
登录后复制

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

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!