jar not loaded,Offending class: javax/servlet/Servlet.class

今天发布项目到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,不再报错,问题解决。

你可能感兴趣的:(servlet,jar,spec,section,loaded,2.3,not,see,class:,9.7.2.,Offending)