文辉居士

tomcat 部署web项目异常

项目部署到Tomcat报这样的异常:validateJarFile jar not loaded. See Servlet Spec 2.3, section 9.7.2. Offending class: javax/servlet/Servlet.class

可能的原因:

造成这种情况的原因很可能是:

一、项目的WEB-INF/lib下有servlet-api.jar。

二、项目的WEB-INF/lib下有包含javax.servlet包的其他JAR包(如WebLogic 8.1的weblogic.jar),造成与Tomcat自身的servlet-api.jar的冲突。因为Tomcat的WebappClassLoader加载JAR包时会进行校验,一旦发现这样的冲突就会报出上面的异常。

解决方案:

tomcat 启动后先将tomcat/common/lib目录下的jar包全部读入内存,如果webapps目录里的应用程序中WEB-INF/lib目录下有相同的包,将无法加载,估计不同版本的包之间也会造成类似问题。因此建议尽量不要把jar包放入tomcat/common/lib目录下,应该放入WEB- INF/lib目录下。

一、针对第一种情况,不要将servlet-api.jar放到WEB-INF/lib下,因为项目部署时根本不需要这个jar包,Tomcat已经提供了。当然如果工程不导入此jar包,在Eclipse里面代码会报错,你可以将servlet-api.jar放在工程下的一个专门的目录(如lib)下面,然后通过Eclipse导入到工程中即可。

二、针对第二种情况,谈谈我的解决办法,在我的项目中由于某种特殊的需求,weblogic.jar是通过自定义的类加载器加载的,而不是由Tomcat的WebappClassLoader加载,所以上述问题也就不存在了。如果您遇到同样的问题,可以借鉴此种方案,只需写一个最简单的类加载器即可。

posted on 2013-09-17 09:57  restService  阅读(1039)  评论(0编辑  收藏  举报

导航


我是有底线的赠送场