发布SpringMVC项目报错java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet

1.问题描述

Spring MVC项目,在build path引入了下列jar包,项目编译没有错,启动tomcat输入项目地址访问就会报错:

java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet
发布SpringMVC项目报错java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet

2.问题定位
编译时没错,在运行时报错,就说明可能发布到tomcat服务器没有找到这个jar包。到tomcat安装目录下查看是否有这个jar包:apache-tomcat-7.0.79\webapps\SpringMVCTest\WEB-INF\lib,经检查,发现是没有的。问题找到了。把上图中的jar包复制到项目的WEB-INF/lib目录下即可
发布SpringMVC项目报错java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet

3.重新部署,启动tomcat访问,一切正常

总结:为何一开始在build path引入了相关jar包,但是发布项目的时候却发布不到tomcat下去呢?网上查了原因:
eclipse引用library 是为了编译代码生成WEB-INF/classes里面的class文件使用;
而tomcat的加载运行机制
1、首先加载Tomcat_HOME/lib目录下的jar包 
2、然后加载Tomcat_HOME/webapps/项目名/WEB-INF/lib的jar包 
3、最后加载的是Tomcat_HOME/webapps/项目名/WEB-INF/classes下的类文件 
所以通过build path引入的jar包只是保证了类在编译的时候可以引用的到,而web-inf/lib下的jar包是运行时必需的jar包。一般的做法是先把jar包放到web-inf/lib下,然后build path的时候,引用该项目的web-inf/lib下的jar包即可