Eclipse报错:java.lang.ClassNotFoundException: ContextLoaderListener

Eclipse 中 tomcat 部署工程启动后报错:

Shell 代码  收藏代码
  1. 严重: Error configuring application listener of class org.springframework.web.context.ContextLoaderListener  
  2. java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener  
  3.     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1678)  
  4.     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1523)  
  5.     at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:415)  
  6.     at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:397)  
  7.     at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:118)  
  8.     at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4660)  
  9.     at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5226)  
  10.     at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5221)  
  11.     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)  
  12.     at java.util.concurrent.FutureTask.run(FutureTask.java:138)  
  13.     at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)  
  14.     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)  
  15.     at java.lang.Thread.run(Thread.java:662)  

问题背景

工程为 maven 工程,ContextLoaderListener 类位于 spring-web-3.1.0.RELEASE.jar 包中。检查了 maven 的 pom.xml,依赖引入正常。在工程 Maven Dependencies 视图中也能看到 spring-web-3.1.0.RELEASE.jar 包被正常引入进来了。

 

错误原因:

进入到 tomcat 的部署路径.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps\ 下检查了一下,发现工程部署后在 WEB-INF 文件夹下没有生成 lib 目录,正常情况下,会生成 lib 目录并把工程的所有依赖 jar 包都部署到该目录下。

 

解决方案:

1. 右键点击项目 -- 选择 Properties

选择 Deployment Assembly, 在右边点击 Add 按钮,在弹出的窗口中选择 Java Build Path Entries。如下图所示:

2. 点击 Next,选择 Maven Dependencies

3. 点击 Finish,然后可以看到已经把 Maven Dependencies 添加到 Web 应用结构中了

 

操作完后,重新部署工程,不再报错了。然后我们再到.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps\ 目录下,发现工程 WEB-INF 目录下自动生成了 lib 目录,并且所有的依赖 jar 包也都已经部署进来。问题因此解决。