Bouncy Castle 多版本 与 Classloader 的问题

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

最近在做一个安全工具, 需要与多个第三方公司进行安全通信, 其中就用到了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)
        at java.lang.Class.newInstance(Class.java:308)
        at java.security.Provider$Service.newInstance(Provider.java:1221)
        at javax.crypto.Cipher.getInstance(DashoA13*..)
        at javax.crypto.Cipher.get
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值