今天发布项目到tomcat中,启动服务器时报错:
信息: Starting Servlet Engine: Apache Tomcat/6.0.20 2015-11-30 9:05:54 org.apache.catalina.loader.WebappClassLoader validateJarFile 信息: validateJarFile(d:\Program Files\Apache Software Foundation\Tomcat 6.0\webapps\xxxx\WEB-INF\lib\javaee.jar) - jar not loaded. See Servlet Spec 2.3, section 9.7.2. Offending class: javax/servlet/Servlet.class
去网上百度了下类似的问题,找到的解决方案如下:
链接:http://blog.sina.com.cn/s/blog_4b5bc011010133te.html
/*****************转载内容**************************************************************************************************/
造成这种情况的原因很可能是:
一、项目的WEB-INF/lib下有servlet-api.jar。
二、项目的WEB-INF/lib下
有包含javax.servlet包的JAR包(如WebLogic 8.1的weblogic.jar),造成与Tomcat自身的servlet-api.jar的冲突。
因为Tomcat的WebappClassLoader加载JAR包时会进行校验。
解决方案:
一、针对第一种情况,项目的servlet-api.jar不要放在WEB-INF/lib下,可以放在工程下的一个专门的目录(如lib)下面,然后通过Eclipse导入到工程中。
二、针对第二种情况,暂时没有想到简单的解决办法,在我的项目中由于某种特殊的需求,weblogic.jar是通过自定义的类加载器加载的,而不是由Tomcat的 WebappClassLoader加载,所以上述问题也就不存在了。如果您遇到同样的问题,可以借鉴此种方案。
/*****************转载内容**************************************************************************************************/
我参考上面的说法,找servlet-api.jar,发现系统里面根本没有这个包,无论是项目下还是tomcat的lib下都没有。我还特意拷贝了这个jar包放到项目下、tomcat的lib下,再重启还是报这个错。后来想想:报错的是javaee这个jar包,我要是删掉应该就没有问题了。有考虑着要是缺了服务器可能没法跑起来,就将javaee剪切到了tomcat的lib,至此:项目中没有javaee jar,tomcat的lib下存在。重启服务器,OK,不再报错,问题解决。