tomcat启动时发生错误springframework.web.context.ContextLoaderListener

来源:互联网 发布:js 什么是原型链 编辑:程序博客网 时间:2024/06/06 17:52

   今天在做一个项目时:tomcat只要启动就会发生错误

严重: Error configuring application listener of class org.springframework.web.context.ContextLoaderListenerjava.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListenerat org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1360)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1206)at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3786)at org.apache.catalina.core.StandardContext.start(StandardContext.java:4350)at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525)at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:924)at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:887)at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492)at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1147)at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)at org.apache.catalina.core.StandardHost.start(StandardHost.java:719)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)at org.apache.catalina.core.StandardService.start(StandardService.java:516)at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)at org.apache.catalina.startup.Catalina.start(Catalina.java:578)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:288)at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)

  
 刚开始我认为是包没有导入,可是我仔细检查了好几遍发现包的导入是正确的啊,为什么会出现这种错误呢?

后来查了好多资料终于弄好了原来是包导入方式的问题:

 我导入的包只是通过java bulid path加入user Librarary的引用,所以我把包重新copy到webroot的web-inf的lib中重新部署启动就ok了

其原因如下:

JVM是根据Java ClassLoader(类加载器)决定如何加载Class。   

系统默认提供了3ClassLoader (Root ClassLoaderClassPathLoaderExtClassLoader   )我们也可以编写自己的ClassLoader,去加载特定环境下的jar文件。     

能不能加载Jar,加载哪里的Jar,是由ClassLoader决定的。

总结:      

WEB Applicationjar包最好放在webroot下的lib文件夹内,特别是xml中用到的jar包。  

 

原创粉丝点击