解决java.lang.NoClassDefFoundError 问题

解决java.lang.NoClassDefFoundError 问题

一、背景

项目运行成功之后,调用某个接口时报错,信息如下:
在这里插入图片描述

2024-04-17 14:59:23 [ERROR] --- [nio-8070-exec-1] c.c.c.e.LogExceptionHandleFilter         : Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: nonapi/io/github/classgraph/utils/ReflectionUtils
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: nonapi/io/github/classgraph/utils/ReflectionUtils
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1087) ~[spring-webmvc-5.3.31.jar:5.3.31]
	at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:965) ~[spring-webmvc-5.3.31.jar:5.3.31]
	at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006) [spring-webmvc-5.3.31.jar:5.3.31]
	....
Caused by: java.lang.NoClassDefFoundError: nonapi/io/github/classgraph/utils/ReflectionUtils
	at com.srdcloud.artifact.app.aspect.permission.PermissionAspect.read(PermissionAspect.java:118) ~[classes/:na]
	at com.srdcloud.artifact.app.aspect.permission.PermissionAspect.interfacePermissionCheck(PermissionAspect.java:60) ~[classes/:na]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_381]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_381]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_381]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_381]
	at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethodWithGivenArgs(AbstractAspectJAdvice.java:634) ~[spring-aop-5.3.31.jar:5.3.31]

参考文章
链接: https://blog.csdn.net/jamesjxin/article/details/46606307

二、分析

  1. 根据报错信息,找到nonapi/io/github/classgraph/utils/ReflectionUtils类,可以看到所属的jar包是classgraph:4.8.83版本
    在这里插入图片描述
  2. 查看项目对应的pom文件,发现引用的classgraph包版本是4.8.147版本的(父级jar包是springdoc-openapi-ui:1.6.9);而且4.8.147版本的classgraph包根本就没有 nonapi/io/github/classgraph/utils/ReflectionUtils这个类
    在这里插入图片描述

在这里插入图片描述
也就是说目前项目中引用的classgraph包版本不是pom文件中所用的版本,且pom中指定的classgraph包版本过高,导致classgraph包原有的方法已经没了

三、解决

由于classgraph包的父级jar包是springdoc-openapi-ui:1.6.9(pom文件中直接引入的是springdoc-openapi-ui),所以需要降低springdoc-openapi-ui版本

我将springdoc-openapi-ui版本降到了1.5.12版本(其实我也是一个个版本慢慢试着降下来才最终确定哪个合适)。

查看springdoc-openapi-ui里的classgraph包版本,发现是4.8.116版本:
在这里插入图片描述
这个版本的classgraph是包含有ReflectionUtils类
在这里插入图片描述
重新启动项目,调用同一个接口,验证通过

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值