赞
踩
项目运行成功之后,调用某个接口时报错,信息如下:
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
nonapi/io/github/classgraph/utils/ReflectionUtils
类,可以看到所属的jar包是classgraph:4.8.83版本
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类
的
重新启动项目,调用同一个接口,验证通过
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。