news 2026/5/28 19:12:43

java.security.InvalidKeyException: IOException : algid parse error, not a sequence 报错解决

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
java.security.InvalidKeyException: IOException : algid parse error, not a sequence 报错解决

错误信息

Caused by: java.security.spec.InvalidKeySpecException: java.security.InvalidKeyException: IOException:algid parse error, not a sequence at jdk.crypto.ec/sun.security.ec.ECKeyFactory.engineGeneratePrivate(ECKeyFactory.java:170)~[jdk.crypto.ec:na]at java.base/java.security.KeyFactory.generatePrivate(KeyFactory.java:389)~[na:na]at io.netty.handler.ssl.SslContext.getPrivateKeyFromByteBuffer(SslContext.java:1236)~[netty-handler-4.2.7.Final.jar:4.2.7.Final]...33common frames omitted Caused by: java.security.InvalidKeyException: IOException:algid parse error, not a sequence at java.base/sun.security.pkcs.PKCS8Key.decode(PKCS8Key.java:135)~[na:na]at java.base/sun.security.pkcs.PKCS8Key.<init>(PKCS8Key.java:95)~[na:na]at jdk.crypto.ec/sun.security.ec.ECPrivateKeyImpl.<init>(ECPrivateKeyImpl.java:78)~[jdk.crypto.ec:na]at jdk.crypto.ec/sun.security.ec.ECKeyFactory.implGeneratePrivate(ECKeyFactory.java:245)~[jdk.crypto.ec:na]at jdk.crypto.ec/sun.security.ec.ECKeyFactory.engineGeneratePrivate(ECKeyFactory.java:166)~[jdk.crypto.ec:na]...35common frames omitted

错误原因

传入的私钥串privateKey格式不是PKC8格式,其中错误的privateKey是通过openssl生成的私钥,将文件中去掉私钥头(-----BEGIN RSA PRIVATE KEY-----)和私钥尾(-----END RSA PRIVATE KEY-----)得到


1)先快速判断server.key是什么

打开D:\test\server.key看第一行:

  • 私钥应该是下面之一:

    • -----BEGIN PRIVATE KEY-----(PKCS#8)
    • -----BEGIN RSA PRIVATE KEY-----(PKCS#1)
    • -----BEGIN EC PRIVATE KEY-----
    • -----BEGIN ENCRYPTED PRIVATE KEY-----(加密私钥)
  • 如果是:

    • -----BEGIN CERTIFICATE-----→ 这是证书,不是私钥
    • 乱码二进制 → 多半是 DER / p12 / jks

2)最稳的修复:把私钥转成PKCS#8(无密码)

不管你原来是什么 PEM 私钥,统一转 PKCS#8 最稳:

openssl pkcs8 -topk8 -inform PEM -in D:\test\server.key -out D:\test\server-pkcs8.key -nocrypt

如果原私钥是加密的,openssl 会提示输入密码。你也可以在 yml 里填serverKeyPassword(但我更建议转成无密码私钥并用文件权限保护)。


3)如果你这套证书是(JKS / P12),需要先导出 PEM 私钥

3.1 如果你有server.p12

openssl pkcs12 -in D:\test\server.p12 -nocerts -nodes -out D:\test\server.key

再执行第 2 步转 PKCS#8。

3.2 如果你只有server.jks

先转 p12:

keytool -importkeystore -srckeystore D:\test\server.jks -srcstoretype JKS -destkeystore D:\test\server.p12 -deststoretype PKCS12

再按 3.1 导出 key,然后按第 2 步转 PKCS#8。


4)验证一下是否成功(建议)

openssl pkey -in D:\test\server-pkcs8.key -text -noout

能正常输出 RSA/EC 信息就对了。


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/20 21:52:59

惊!1区TOP顶刊,受运营资源调整停止收稿!或因停刊被SCI剔除?

本期解刊《Environmental Health Perspectives》环境类中科院 1 区顶级期刊《Environmental Health Perspectives》自2025年4月23日起&#xff0c;在官网发布重磅公告&#xff1a;受运营资源调整影响&#xff0c;即日起暂停接收新投稿件。现阶段尚在投稿流程及处于审稿环节的稿…

作者头像 李华
网站建设 2026/5/28 10:21:11

PowerBI主题模板终极指南:30+预设模板轻松美化数据报表

PowerBI主题模板终极指南&#xff1a;30预设模板轻松美化数据报表 【免费下载链接】PowerBI-ThemeTemplates Snippets for assembling Power BI Themes 项目地址: https://gitcode.com/gh_mirrors/po/PowerBI-ThemeTemplates 想要快速提升Power BI报表的视觉吸引力吗&am…

作者头像 李华
网站建设 2026/5/26 19:31:07

完全掌握前端图片水印:watermark.js实战指南

您是否曾担心自己精心拍摄的照片在网上被他人随意盗用&#xff1f;是否希望在用户上传图片时自动添加版权标识&#xff1f;今天&#xff0c;我将带您深入了解watermark.js这个强大的浏览器端JavaScript水印库&#xff0c;让您轻松实现前端图片水印和版权保护功能。 【免费下载链…

作者头像 李华
网站建设 2026/5/20 21:02:53

重塑笔记体验:Obsidian首页模板的个性化定制之道

你是否曾为杂乱无章的笔记界面而烦恼&#xff1f;Obsidian首页模板正是解决这一痛点的完美方案。通过极简美学设计与模块化功能组件&#xff0c;这款模板让你在打开笔记软件的第一刻就感受到效率的提升和视觉的愉悦。 【免费下载链接】obsidian-homepage Obsidian homepage - M…

作者头像 李华
网站建设 2026/5/26 9:12:32

Bruno事务测试架构设计:分布式系统原子操作验证方法论

Bruno事务测试架构设计&#xff1a;分布式系统原子操作验证方法论 【免费下载链接】bruno 开源的API探索与测试集成开发环境&#xff08;作为Postman/Insomnia的轻量级替代方案&#xff09; 项目地址: https://gitcode.com/GitHub_Trending/br/bruno 问题诊断&#xff1…

作者头像 李华
网站建设 2026/5/20 17:38:03

构建可持续开源生态:Champ项目的5大治理实践

构建可持续开源生态&#xff1a;Champ项目的5大治理实践 【免费下载链接】champ Champ: Controllable and Consistent Human Image Animation with 3D Parametric Guidance 项目地址: https://gitcode.com/GitHub_Trending/ch/champ 开源项目的成功不仅需要技术创新&…

作者头像 李华