最近新建了一个JSF项目(网上查到用Struts,Spring MVC也会如此),配置好以后用Eclipse启动Tomcat报了如下错误:严重: Error loading WebappClassLoader

  1. context: /jsf2nd
  2. delegate: false
  3. repositories:
  4. /WEB-INF/classes/
  5. ----------> Parent Classloader:
  6. org.apache.catalina.loader.StandardClassLoader@1172e08
  7. javax.faces.webapp.FacesServlet
  8. java.lang.ClassNotFoundException: javax.faces.webapp.FacesServlet
  9. at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)
  10. at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)
  11. at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1128)
  12. at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1026)
  13. at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4421)
  14. at org.apache.catalina.core.StandardContext.start(StandardContext.java:4734)
  15. at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057)
  16. at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)
  17. at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057)
  18. at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)
  19. at org.apache.catalina.core.StandardService.start(StandardService.java:525)
  20. at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)
  21. at org.apache.catalina.startup.Catalina.start(Catalina.java:595)
  22. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  23. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
  24. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
  25. at java.lang.reflect.Method.invoke(Method.java:597)
  26. at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
  27. at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
  28. 2011-12-8 9:11:27 org.apache.catalina.core.StandardContext loadOnStartup
  29. 严重: Servlet /jsf2nd threw load() exception
  30. java.lang.ClassNotFoundException: javax.faces.webapp.FacesServlet
  31. at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)
  32. at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)
  33. at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1128)
  34. at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1026)
  35. at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4421)
  36. at org.apache.catalina.core.StandardContext.start(StandardContext.java:4734)
  37. at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057)
  38. at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)
  39. at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057)
  40. at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)
  41. at org.apache.catalina.core.StandardService.start(StandardService.java:525)
  42. at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)
  43. at org.apache.catalina.startup.Catalina.start(Catalina.java:595)
  44. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  45. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
  46. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
  47. at java.lang.reflect.Method.invoke(Method.java:597)
  48. at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
  49. at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)

网 上搜了几种解决方案:1、关掉myeclipse,把原来的tomcat换掉,如果是安装版的就卸载,重新放一个tomcat,启动myeclipse, 配置tomcat,部署,再启动tomcat,一切OK。2、之前jar包我是通过Build path -> Configure build path-> Add External JARs的方式添加的,程序编译,Tomcat启动都很正常,没有错误。可是一访问jsp页面就报上述错误。 苦思不得其解,但看了错误信息说是找不到 org.springframework.web.servlet.DispatcherServlet类,所以我就干脆将 spring.jar,spring-webmvc.jar等jar包通通手工添加到/WEB-INF/lib目录下,并且将default output folder值改为projectName/WebContent/WEB-INF/classes 问题就得以解决了。

这 两种解决方案试了都不行,但是大体了解到可能是jar包没有导入进去,所以进了eclipse的工程目录,找到对应的存放jar包的目 录:.metadata\.plugins\org.eclipse.wst.server.core\tmp3\wtpwebapps\jsf2nd \WEB-INF\lib,发现果然少了两个jar包,将之放入后问题就解决了。

错误原因:至今未能查明究竟是哪个地方出错了才使得eclipse不能将jar包放到eclipse的tomcat插件下面。

可能的几个原因:1、我的eclipse选择的默认编译是jdk1.5,而这个项目用的是Tomcat6, 2、我的Eclipse里面默认设置的tomcat的编译器也是1.5

解决Eclipse启动Tomcat时报Error loading WebappClassLoader错误的更多相关文章

  1. Eclipse启动tomcat时报错:Multiple Contexts have a path of "/xxx"

    今天使用Eclipse启动tomcat部署项目时,遇到一个奇怪的错误: Could not publish server configuration for Tomcat v6.0 Server at ...

  2. eclipse启动Tomcat时报错:严重: Exception loading sessions from persistent storage

    我的项目工程是Spring+hibernate+structs  1.0,最近启动tomcat时多次遇到如下异常: 严重: IOException while loading persisted se ...

  3. 用eclipse启动tomcat时报Could not publish server configuration for Tomcat v8.0 Server at localhost..错误

    网上的解决方法是: 1.如果是使用的eclipse tomcat 插件,需要在你的工作空间 找到如下文件:.metadata.plugins\org.eclipse.wst.server.cor\e\ ...

  4. 解决eclipse启动tomcat报错:Could not load the Tomcat server configuration at \Servers\Tomcat v6.0 Server at localhost-config. The Servers project is closed.

    报错信息已经说的很清楚了:The Servers project is closed.如图 打开即可: 另外,如果你修改了Servers project的name(比如说把这里的Servers改成了X ...

  5. 用Eclipse的tomcat插件启动tomcat时报错:

    用Eclipse的tomcat插件启动tomcat时报错: FATAL ERROR in native method: JDWP No transports initialized, jvmtiErr ...

  6. MyEclipse 启动tomcat时报错:Cannot change deployment state from ERROR to REDEPLOYING.ds

    myeclipse 启动tomcat时报错:Cannot change deployment state from ERROR to REDEPLOYING.ds - 刘琦的专栏 - 博客频道 - C ...

  7. [转]Eclipse启动Tomcat时45秒超时解决方法

    原文地址:http://it.oyksoft.com/post/6577/ Eclipse启动Tomcat时,默认配置的启动超时时长为45秒.假若项目启动超过45秒将会报错.两种解决方法:1.改XML ...

  8. Springmvc+Hibernate在Eclipse启动Tomcat需要很长时间的解决方法

    最近在学习SpringMvc开发,有一个提问困扰了很久,就是在Eclipse启动Tomcat需要很长时间,大概要1分多钟. 启动日志: 九月 08, 2016 8:59:01 下午 org.apach ...

  9. Eclipse启动Tomcat时45秒超时的解决方法

    Eclipse启动Tomcat时,默认配置的启动超时时长为45秒.假若项目需要加载的东西比较多,启动时间会比较久,如果启动超过45秒将会报错.有两种解决途径,方法只有一个,就是修改启动时间. 1. 修 ...

随机推荐

  1. iOS中的通知

    一.了解几个相关的类 1.NSNotification 这个类可以理解为一个消息对象,其中有三个成员变量. 这个成员变量是这个消息对象的唯一标识,用于辨别消息对象. @property (readon ...

  2. CodeForces 219D 树形DP

    D. Choosing Capital for Treeland time limit per test 3 seconds memory limit per test 256 megabytes i ...

  3. 大数相乘nyoj28

    描述我们都知道如何计算一个数的阶乘,可是,如果这个数很大呢,我们该如何去计算它并输出它?   输入 输入一个整数m(0<m<=5000) 输出 输出m的阶乘,并在输出结束之后输入一个换行符 ...

  4. 20145337《JAVA程序设计》第七周学习总结

    20145337 <Java程序设计>第七周学习总结 教材学习内容总结 时间的度量 格林威治时间GMT,世界时UT,国际原子时TAI,世界协调时间UTC 就目前来说,即使标注为GMT,实际 ...

  5. Bootstrap css栅格 + 网页中插入代码+css表格

    设计达人 http://www.shejidaren.com/30-minimal-app-icons.html CSS栅格: <!DOCTYPE html> <html lang= ...

  6. BizTalk2010动手实验(二)第一个BizTalk应用

    1 课程简介 通过本课程了解BizTalk 的消息机制,发布与订阅机制 2 准备工作 3 操作步骤 3.1 创建BizTalk应用程序 1. 新建应用程序 2. 输入应用程序名称 3.2 创建与配置接 ...

  7. ARM的一些基本概念

    MPU介绍: mpu是一个芯片,重力加速器(加速度)和陀螺仪(角速度) iic总线.在板上有iic控制器 连接着 最多128个外设,每个外设有地址,可以通信. 寄存器: cpu中的寄存器是为了加快运算 ...

  8. Java封装

    面向对象的三大特征:封装.继承.多态.封装在书面上来说,他无非就是set和get方法罢了.为什么要用到封装,比如买主机如果没有机箱只有内存条.CPU.主板等等那些零件买回到家,你还得一个个的去装那些零 ...

  9. A trip through the Graphics Pipeline 2011_11 Stream Out

    Welcome back! This time, the focus is going to be on Stream-Out (SO). This is a facility for storing ...

  10. 12.162s 1805.867s

    [SQL]DROP PROCEDURE IF EXISTS truncate_insert_sales_rank_toparow_week; 受影响的行: 时间: .001s [SQL] CREATE ...