加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

如何使用golang加密写出ecdsa密钥?

发布时间:2020-12-16 19:03:21 所属栏目:大数据 来源:网络整理
导读:我有一些Go代码生成一个ECDSA密钥并将其写入文件: priv,err := ecdsa.GenerateKey(elliptic.P256(),rand.Reader)ecder,err := x509.MarshalECPrivateKey(priv)keypem,err := os.OpenFile("ec-key.pem",os.O_WRONLY|os.O_CREATE|os.O_TRUNC,0600)pem.Encode(
我有一些Go代码生成一个ECDSA密钥并将其写入文件:
priv,err := ecdsa.GenerateKey(elliptic.P256(),rand.Reader)
ecder,err := x509.MarshalECPrivateKey(priv)
keypem,err := os.OpenFile("ec-key.pem",os.O_WRONLY|os.O_CREATE|os.O_TRUNC,0600)
pem.Encode(keypem,&pem.Block{Type: "EC PRIVATE KEY",Bytes: ecder})

这适用于并生成“BEGIN EC PRIVATE KEY”块.但是当你在openssl中写出密钥时,你也会得到一个“BEGIN EC PARAMETERS”块,指定使用的曲线.有没有办法将EC参数写入Go中的pem文件?

到目前为止,我发现了一种丑陋的方式:

对于命名曲线,openssl将ASN.1 OID写入EC PARAMETERS块.所以我从http://www.ietf.org/rfc/rfc5480.txt开始查看P256曲线的OID并添加:

secp256r1,err := asn1.Marshal(asn1.ObjectIdentifier{1,2,840,10045,3,1,7})
pem.Encode(keypem,&pem.Block{Type: "EC PARAMETERS",Bytes: secp256r1})

这适用于我目前的用例,但我不知道是否可以这样做一般..

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读