Eclipse报错:java.lang.ClassNotFoundException: ContextLoaderListener

来源:互联网 发布:深入浅出java中文版 编辑:程序博客网 时间:2024/05/15 14:05

启动项目的时候经常遇到这个错误,方便以后快速解决记录一下。

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

java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener

java.lang.ClassNotFoundException: com.alibaba.dubbo.remoting.http.servlet.BootstrapListener

二月 20, 2017 10:41:49 上午 org.apache.catalina.core.StandardContext listenerStart严重: Error configuring application listener of class org.apache.catalina.deploy.ApplicationListener@26e0108ajava.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1714)    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559)    at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:527)    at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:509)    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:137)    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4854)    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5434)    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)    at java.util.concurrent.FutureTask.run(Unknown Source)    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)    at java.lang.Thread.run(Unknown Source)二月 20, 2017 10:41:49 上午 org.apache.catalina.core.StandardContext listenerStart严重: Error configuring application listener of class org.apache.catalina.deploy.ApplicationListener@215e8db2java.lang.ClassNotFoundException: com.alibaba.dubbo.remoting.http.servlet.BootstrapListener    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1714)    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559)    at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:527)    at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:509)    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:137)    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4854)    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5434)    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)    at java.util.concurrent.FutureTask.run(Unknown Source)    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)    at java.lang.Thread.run(Unknown Source)

问题背景

工程为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.选择Maven Dependencies,然后点击finish

3.然后可以看到已经把Maven Dependencies添加到Web Deployment Assembly中了,最后点击apply ---> OK。

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

最后附上转载博主地址。http://chenzhou123520.iteye.com/blog/1836987

0 0
原创粉丝点击