eclipse - 运行 Tomcat + Spring + Maven 项目时出现 NoClassDefFoundError (Eclipse)

标签 eclipse spring tomcat maven noclassdeffounderror

我得到的是:

java.lang.NoClassDefFoundError: com/mongodb/DB
at java.lang.Class.getDeclaredMethods0(Native Method)
at java.lang.Class.privateGetDeclaredMethods(Class.java:2427)
at java.lang.Class.getDeclaredMethods(Class.java:1791)
at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:446)
at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:430)
at org.springframework.util.ReflectionUtils.getAllDeclaredMethods(ReflectionUtils.java:475)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getTypeForFactoryMethod(AbstractAutowireCapableBeanFactory.java:634)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.predictBeanType(AbstractAutowireCapableBeanFactory.java:573)
at org.springframework.beans.factory.support.AbstractBeanFactory.isFactoryBean(AbstractBeanFactory.java:1319)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanNamesForType(DefaultListableBeanFactory.java:315)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeansOfType(DefaultListableBeanFactory.java:394)
at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:594)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:407)
at org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:442)
at org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:458)
at org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:339)
at org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:306)
at org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:127)
at javax.servlet.GenericServlet.init(GenericServlet.java:212)
at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1173)
at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:993)
at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4420)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4733)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)
at org.apache.catalina.core.StandardService.start(StandardService.java:525)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)
at org.apache.catalina.startup.Catalina.start(Catalina.java:595)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)

此类位于 maven jar 中(来自 M2 存储库)。我将 Maven 依赖项添加到 DeploymentAssembly(在我这样做之前我得到:java.lang.ClassNotFoundException: org.springframework.web.filter.CharacterEncodingFilter)。我使用 m2e 插件并将我的项目配置为 Maven 项目。我的应用程序部署到标准位置/.metadata/.plugins/.../tmp0。在 WEB-INF/lib 里面,我有所有必要的 jar 。项目编译没有错误。我能做错什么吗?

一个准解决方案是将必要的库添加到 Tomcat lib 目录,但我不想这样做。我想强制 Tomcat 使用项目库。

最佳答案

我在尝试运行 mcv-ajaxmvc-basic 示例时遇到了类似的问题,它们随 Spring 3 一起分发(两者可在 https://src.springframework.org/svn/spring-samples 获得——需要一个 SVN 客户端来下载它们,比如 TortoiseSVN)。

我在我的 Tomcat6 启动日志中收到这个 ClassNotFoundException。

SEVERE: Exception starting filter characterEncodingFilter java.lang.ClassNotFoundException: org.springframework.web.filter.CharacterEncodingFilter
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:269)
    at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:422)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:115)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4071)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4725)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)
    at org.apache.catalina.core.StandardService.start(StandardService.java:525)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:595)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Feb 17, 2012 10:36:18 AM org.apache.catalina.core.StandardContext start
SEVERE: Error filterStart
Feb 17, 2012 10:36:18 AM org.apache.catalina.core.StandardContext start
SEVERE: Context [/mvc-basic] startup failed due to previous errors

我可以同时运行 Maven Clean 和 Maven Install 目标,没有错误,并且项目没有任何类路径错误。 我还安装了 Maven Integration for Eclipse Extras 包下的 eclipse Maven Integration for WTP,按照说明 here , 但仍然没有运气......

我的问题可以在 Eclipse 的 Markers 选项卡中看到,作为警告(黄色感叹号)和 Classpath Dependency validator Message 的描述 并且 classpath 条目 org.eclipse.maven2_classpath.container 的实际问题将不会被导出或发布。可能会导致运行时 ClassNotFoundExceptions。

To solve this issue

  1. 右键单击问题描述,然后选择快速修复。
  2. 选择将关联的原始类路径条目标记为发布/导出依赖项
  3. 点击完成
  4. 执行ma​​ven-cleanma​​ven-install
  5. 右键单击项目,选择在服务器上运行。选择要运行的 Tomcat 服务器,您应该会看到初始页面。

Conclusion The steps described above, worked for me in making the project run successfully in my Eclispe Development Environment. Please give it a try to see if it will work for you.

另一种似乎也有效的解决方案是

  1. 从 eclipse 中删除项目,包括工作区中的所有关联文件。 (同时从工作区中删除项目目录)
  2. 再次将项目从 SVN checkout 到工作区
  3. 在eclipse中导入新项目,但选择Maven\Existing Maven Project
  4. 从磁盘中选择项目并导入。

亲切的问候,

ta6hbe

关于eclipse - 运行 Tomcat + Spring + Maven 项目时出现 NoClassDefFoundError (Eclipse),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6760775/

相关文章:

spring - 当被 Spring 代理类访问时,Kotlin 实例变量为空

java - Tomcat 日志属性过滤

c++ - Eclipse 朱诺 CDT 错误 : No rule to make target `all'

java - 工作区设置与项目特定设置

java - 这两个设置在 Maven 中是否相同?

java - spring 3.0 包含哪些 maven 依赖项?

java - 可以检查哪部分代码花费太多时间的 Eclipse 插件?

java - WebClient - 如何获取请求正文?

postgresql - 如何消除对两个共同使用桥接网络的 docker 容器的需求?

apache - 域根上的 Artifactory apache2 代理