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

本文介绍了一种在使用Dubbo框架时遇到的ClassNotFoundException问题,详细分析了错误原因,并给出了具体的解决方案,包括更改Javassist版本。

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

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>
HTTP状态 500 - 内部服务器错误 类型 异常报告 消息 org.apache.jasper.JasperException: java.lang.ClassNotFoundException: org.apache.jsp.Page_jsp 描述 服务器遇到一个意外的情况,阻止它完成请求。 例外情况 org.apache.jasper.JasperException: org.apache.jasper.JasperException: java.lang.ClassNotFoundException: org.apache.jsp.Page_jsp org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:578) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:422) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:377) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:325) jakarta.servlet.http.HttpServlet.service(HttpServlet.java:658) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) 根本原因。 org.apache.jasper.JasperException: java.lang.ClassNotFoundException: org.apache.jsp.Page_jsp org.apache.jasper.servlet.JspServletWrapper.getServlet(JspServletWrapper.java:194) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:410) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:377) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:325) jakarta.servlet.http.HttpServlet.service(HttpServlet.java:658) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) 根本原因。 java.lang.ClassNotFoundException: org.apache.jsp.Page_jsp java.base/java.net.URLClassLoader.findClass(URLClassLoader.java:445) org.apache.jasper.servlet.JasperLoader.loadClass(JasperLoader.java:129) org.apache.jasper.servlet.JasperLoader.loadClass(JasperLoader.java:58) org.apache.jasper.servlet.JspServletWrapper.getServlet(JspServletWrapper.java:189) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:410) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:377) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:325) jakarta.servlet.http.HttpServlet.service(HttpServlet.java:658) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) ):注意 主要问题的全部 stack 信息可以在 server logs 里查看 Apache Tomcat/10.1.28
06-08
2025-3-21 上午09时48分45秒 CKD <Warning> <org.hibernate.tuple.entity.Pojohnti:v/Uplizer> CERA-000000> <could not create proxy factory for:com.tapi.application.ppmll.dto.domain @uPolicyInvok colnfoDto org.hibernate.hibernateException: javassist Enhancement failed: com.tapi.application.ppmll.dto.domain.0aPolicylnvok.colnfoDto at org.hibernate.proxy.polo_javassist.JavassistLayoutInitializer.getProxyFactory(javassistLayoutUtilizer.java:169) at org.hibernate.proxy.polo_javassist.JavassistProxyFactory.postInstantiate(javassistProxyFactory.java:68) at org.hibernate.tuple.entity.Pojohnti:v/Uplizer.buildProxyFactory(Pojohnti:v/Uplizer.java:188) at org.hibernate.tuple.entity.AbsetractEntityImpl.java:<in1>(AbstractEntityImplizer.java:151) at org.hibernate.tuple.entity.Pojohnti:v/Uplizer.<in1>(ProjectEntityImplizer.java:78) Caused By: java.lang.RuntimeException: duplicate method: at javassist.util.proxy.ProxyFactory.createClassOfProxyFactory.java:509 at javassist.util.proxy.ProxyFactory.createClassOfProxyFactory.java:480 at javassist.util.proxy.ProxyFactory.createClassOfProxyFactory.java:422 at javassist.util.proxy.ProxyFactory.createClass(ProxyFactory.java:394) at org.hibernate.tuple.polo_javassist.JavassistLayoutInitializer.getProxyFactory(javassistLayoutUtilizer.java:162) Tuncated_see log file for complete stacktrace Caused By: javassist_bytecode.DaplicationCompleteCaption: duplicate method: getHandler in com.tapi.application.ppmll.dto.domain.0aPolicylnvok.colnfoDto_33_javassist_2003 at javassist_bytecode.ClassFile.callatingButtonOldClassFile.java:864) at javassist_bytecode.ClassFile.addMethod(ClassFile.java:A40) at javassist.util.proxy.ProxyFactory.addCenter(ProxyFactory.java:898) at javassist.util.proxy.ProxyFactory.make(ProxyFactory.java:717) at javassist.util.proxy.ProxyFactory.createClassOfProxyFactory.java:497) Tuncated_see log file for complete stacktrace
03-24
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值