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

如何使用golang加密写出ecdsa密钥?,第1张

概述我有一些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|o 我有一些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})

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

总结

以上是内存溢出为你收集整理的如何使用golang加密写出ecdsa密钥?全部内容,希望文章能够帮你解决如何使用golang加密写出ecdsa密钥?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1293727.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-10
下一篇 2022-06-10

发表评论

登录后才能评论

评论列表(0条)

保存