我有一些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})
这适用于我目前的用例,但我不知道是否可以这样做一般..
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。