Bouncy Castle 多版本 与 Classloader 的问题

在与第三方公司的安全通信中遇到Bouncy Castle异常。问题源于不同Classloader加载了不同版本的Bouncy Castle库,导致低版本覆盖高版本,引发错误。通过检查Classloader并升级Bouncy Castle版本至1.5解决了问题。理解Java的Classloader双亲委派机制对于排查这类问题至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在做一个安全工具, 需要与多个第三方公司进行安全通信, 其中就用到了Bouncy Castle.

 

在连接B公司时,偶尔就会出现这样的异常:

 

java.lang.NoClassDefFoundError: org/bouncycastle/crypto/engines/RC2Engine
        at org.bouncycastle.jce.provider.JCEBlockCipher$PBEWithSHAAnd40BitRC2.<init>(JCEBlockCipher.java:906)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
        at java.lang.Class.newInstance0(Class.java:355)
    &nbs
服务器上使用jar -tf ruoyi-admin-nrp.jar | grep org/bouncycastle命令发现无输出,但是在windows系统使用mvn dependency:tree时里面有[INFO] +- org.dromara:ruoyi-common-encrypt:jar:5.2.0:compile [INFO] | +- org.bouncycastle:bcprov-jdk15to18:jar:1.76:compile 最后在服务上使用jar -tf ruoyi-admin-nrp.jar发现有BOOT-INF/lib/bcprov-jdk15to18-1.76.jar 本地使用Cipher cipher = Cipher.getInstance("SM2", "BC");时正常运行,这条代码在 org.dromara:ruoyi-common-encrypt中,服务器上运行这条代码则报错java.security.NoSuchAlgorithmException: No such algorithm: SM2 我的是spring程序 工具类使用时有注册 package org.dromara.common.encrypt.utils; import org.bouncycastle.crypto.CipherParameters; import org.bouncycastle.crypto.engines.SM4Engine; import org.bouncycastle.crypto.modes.CBCBlockCipher; import org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher; import org.bouncycastle.crypto.params.KeyParameter; import org.bouncycastle.crypto.params.ParametersWithIV; import org.bouncycastle.jce.provider.BouncyCastleProvider; import org.bouncycastle.util.encoders.Base64; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import java.nio.charset.StandardCharsets; import java.security.*; import java.security.spec.X509EncodedKeySpec; public class Sm4CBCUtils { public static final int DEFAULT_KEY_SIZE = 128; public static final String ALGORITHM_NAME = "SM4"; static { Security.addProvider(new BouncyCastleProvider()); }
最新发布
07-31
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值