javassist 版本导致ClassNotFoundException: javassist.ClassPath异常

1、异常描述

使用Dubbo时,引入了javassist导致出现了ClassNotFoundException: javassist.ClassPath异常,因为此异常网上资料较少,特分享出来供大家脱坑:
服务启动后报错:

message:  Context initialization failed (o.s.web.context.ContextLoader:350) [localhost-startStop-1] 
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'com.wesd.hrhx.service.dubbo.DebtDubboService': Instantiation of bean failed; nested exception is java.lang.ExceptionInInitializerError.

2、异常定位

从错误信息中可看出,错误来源于Spring注入DebtDubboService出错,我们继续往下找具体的原因:

Caused by: java.lang.NoClassDefFoundError: javassist/ClassPath
at java.lang.Class.forName0(Native Method)

仔细分析下Spring的Ioc原理即知:Spring使用类加载器加载类时,找不到javassist/ClassPath。

3、异常处理

可是查看项目下发现依赖的包javassist-3.18.1-GA.jar,打开这些jar包,其中的javassist.ClassPath的确存在啊,于是我换了个版本javassist-3.18.2-GA.jar程序跑起来了。
其实就是因为JavassistCompile使用了类javassist.ClassPath。经过一点点的比较,最后发现 javassist-3.18.1-GA.jar这个包是有问题的,因为其MAINFEST.FM文件是打不开的,解压以后也报各种Class文件格式错误。

解决方案:
更换javassist版本:

<dependency>
    <groupId>org.javassist</groupId>
    <artifactId>javassist</artifactId>
    <version>3.20.0-GA</version>
</dependency>

猜你喜欢

转载自blog.csdn.net/hehuanchun0311/article/details/79755266