使用maven搭建项目(这个错误和是不是使用maven搭建项目没有关系),然后部署到tomcat中运行。
出现问题1:
tomcat跑起来了,但是启动时间很短,没有报错,项目不能正常访问
项目启动时间很短,并且没有报错
并且项目无法正常访问
发现问题过程:
查看tomcat下,发现这个项目在tomcat的webapps下部署的仅仅是项目的部分文件,有好多的东西并没有部署进来
我们发现tomcat下部署的本项目中 并没有lib依赖包库 等目录。
解决途径:
因此我们需要通过 使用deployment assembly为web工程指定在运行的时候,指定将依赖的工程打成jar包部署到web-inf/lib下
也就是通过这个设置项目在tomcat中要打包部署的东西
将这个选择添加到我们需要打包部署的目录中
这样 项目就可以启动起来了。
问题2:项目启动,会报错java.lang.ClassNotFoundException: ContextLoaderListener
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:1680) 4 at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526) 5 at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4153) 6 at org.apache.catalina.core.StandardContext.start(StandardContext.java:4709) 7 at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:802) 8 at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779) 9 at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:583) 10 at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1080) 11 at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:1003) 12 at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:507) 13 at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1322) 14 at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:325) 15 at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142) 16 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1068) 17 at org.apache.catalina.core.StandardHost.start(StandardHost.java:822) 18 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1060) 19 at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463) 20 at org.apache.catalina.core.StandardService.start(StandardService.java:525) 21 at org.apache.catalina.core.StandardServer.start(StandardServer.java:759) 22 at org.apache.catalina.startup.Catalina.start(Catalina.java:595) 23 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 24 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 25 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 26 at java.lang.reflect.Method.invoke(Method.java:606) 27 at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289) 28 at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414) 29 六月 23, 2016 4:24:17 下午 org.apache.catalina.core.StandardContext listenerStart 30 严重: Error configuring application listener of class org.springframework.web.util.IntrospectorCleanupListener 31 java.lang.ClassNotFoundException: org.springframework.web.util.IntrospectorCleanupListener 32 at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680) 33 at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526) 34 at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4153) 35 at org.apache.catalina.core.StandardContext.start(StandardContext.java:4709) 36 at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:802) 37 at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779) 38 at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:583) 39 at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1080) 40 at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:1003) 41 at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:507) 42 at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1322) 43 at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:325) 44 at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142) 45 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1068) 46 at org.apache.catalina.core.StandardHost.start(StandardHost.java:822) 47 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1060) 48 at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463) 49 at org.apache.catalina.core.StandardService.start(StandardService.java:525) 50 at org.apache.catalina.core.StandardServer.start(StandardServer.java:759) 51 at org.apache.catalina.startup.Catalina.start(Catalina.java:595) 52 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 53 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 54 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 55 at java.lang.reflect.Method.invoke(Method.java:606) 56 at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289) 57 at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
这个报错信息显示,我们web.xml中配置的这两个Listener所依赖的类找不到:
就是这两个listener:
1 <!-- 监听servletContext,启动contextConfigLocation中的spring配置信息 --> 2 <listener> 3 <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 4 </listener> 5 6 7 <!-- 防止spring内存溢出监听器 可用可不用--> 8 <listener> 9 <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class> 10 </listener>
发现问题的过程:
但是我们在maven的pom.xml中已经将它所依赖的架包全都导入了。
工程为maven工程,ContextLoaderListener类位于spring-web-3.1.0.RELEASE.jar包中。检查了maven的pom.xml,依赖引入正常。在工程Maven Dependencies视图中也能看到spring-web-3.1.0.RELEASE.jar包被正常引入进来了。
解决途径:
所以,应该是项目中所依赖的架包什么的都没有被正常的打包部署到tomcat下
添加后,重新clean一下项目,然后启动起来项目正常启动!!!!