使用Maven打包bouncycastle出现JCE cannot authenticate the provider BC的原因及解决办法
摘抄自:https://www.cnblogs.com/WriteOnce/p/14954460.html
问题描述
在写一个加解密的控制台小程序时报错如下:
Caused by: java.lang.SecurityException: JCE cannot authenticate the provider BC
问题原因
其实原因也很简单 当在编辑器里运行的时候 使用的jar包是maven下载好的引用
而当使用maven打包的时候 mvn会将引用的jar包 解包然后重新打包
但是因为bouncycastle包有签名 maven的解包操作导致了签名失效 从而无法再使用。而本地的jre环境也没有这个jar包 就导致了JCE无法验证。
这也是为什么可以直接把jar包扔到jre里可以解决这个问题。
解决方法
1、推荐使用官方建议的使用jar in jar插件
官方文档 https://pulsar.apache.org/docs/zh-CN/security-bouncy-castle/
打包插件 https://github.com/nthuemmel/executable-packer-maven-plugin
(如果你使用的是eclipse打包 直接有选项可以实现jar in jar。不需要使用插件)
插件使用方法 mainClass为启动类。还有一些其他功能配置 可以自行在git仓库查看
<plugin>
<groupId>de.ntcomputer</groupId>
<artifactId>executable-packer-maven-plugin</artifactId>
<version>1.0.1</version>
<configuration>
<mainClass>你的主类</mainClass>
</configuration>
<executions>
<execution>
<goals>
<goal>pack-executable-jar</goal>
</goals>
</execution>
</executions>
</plugin>
运行 mvn package 后,生成的JAR文件位于 target/
最后说说executable-packer-maven-plugin插件做了啥
首先会将所有依赖的第三方jar包直接打到你的jar包中。然后修改启动类为他的ExecutableLauncher
这个类会在启动时加载所有的第三方jar包 最后再反射启动你真正要用的mainClass
分类:
Java
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具