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

为什么在 Go 中解密我的 PKCS8 私钥时出现'x509:块中没有 DEK-Info header”错误?

Mary-Kate Olsen
发布: 2024-11-01 00:23:02
原创
618 人浏览过

Why Am I Getting

排查加密私钥解密错误

尝试在 Go 中读取加密的 PKCS8 私钥文件时,开发者可能会遇到以下情况错误:“x509:块中没有 DEK-Info 标头。”此错误表明库无法解密密钥。

用户提供了使用 OpenSSL 的示例密钥生成过程:

openssl genrsa -out file.pem -passout pass:file -aes256 1024
openssl pkcs8 -topk8 -inform pem -in file.pem -outform pem -out filePKCS8.pem
登录后复制

并尝试在 Go 中解密密钥:

<code class="go">block, _ := pem.Decode(key)
return x509.DecryptPEMBlock(block, password)</code>
登录后复制

然而,标准 Go 库缺少解密加密 PKCS8 密钥的函数。要解决此问题,请考虑使用第三方软件包,例如:

<code class="go">https://github.com/youmark/pkcs8/blob/master/pkcs8.go#L103</code>
登录后复制

此软件包提供了在 Go 中解密加密 PKCS8 密钥所需的功能。

以上是为什么在 Go 中解密我的 PKCS8 私钥时出现'x509:块中没有 DEK-Info header”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

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