当前位置:   article > 正文

解决java.lang.NoClassDefFoundError 问题

解决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]

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

参考文章
链接: 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类
在这里插入图片描述
重新启动项目,调用同一个接口,验证通过

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/462855
推荐阅读
相关标签
  

闽ICP备14008679号