为什么tomcat在寻找JSF类?

时间:2008-11-03 16:30:37

标签: java tomcat jsf

我正在努力让我的开发环境正常运行,而我在使用Tomcat尝试加载JSF类时遇到了麻烦。我的应用程序不使用JSF;事实上,我还没有将我的应用程序部署到tomcat。我在启动日志中获得了大量的堆栈跟踪,当我尝试打开http://localhost:8080时,我无法加载默认的tomcat主页(我只是得到了tomcat 404页面)。

以下是第一个堆栈跟踪:

SEVERE: Error configuring application listener of class com.sun.faces.util.ReflectionUtils$ReflectionUtilsListener
java.lang.ClassNotFoundException: com.sun.faces.util.ReflectionUtils$ReflectionUtilsListener
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1386)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1232)
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3712)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4216)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:760)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:740)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:544)
    at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:626)
    at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:553)
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:488)
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1150)
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:120)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1022)
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:736)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1014)
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
    at org.apache.catalina.core.StandardService.start(StandardService.java:448)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:700)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:552)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:324)
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:295)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:433)

我也为以下其他类获得类似的堆栈跟踪:

com.sun.faces.config.ConfigureListener
com.sun.faces.application.WebappLifecycleListener

我不确定这是否相关,但我在Mas OS 10.5上运行Tomcat 5.5.27并安装了1.4兼容包,Java 1.4.2。

感谢您的任何想法!

编辑:似乎Tomcat附带的每个默认应用程序(主机管理器,平衡器,tomcat-docs,jsp-examples等)都依赖于这些JSF类。我删除了这些默认应用程序,似乎一切正常。

所以,我现在的问题是: 为什么tomcat会附带不包含其依赖项的应用程序,我需要做些什么来使这些默认应用程序正常工作?

2 个答案:

答案 0 :(得分:3)

您的tomcat安装是否完全干净,还是您继承的?

检查webapps是否包含可能引用JSF类的现有战争/目录?

更新:啊 - 我看到你发现了这种情况: - )

不确定为什么tomcat不包含所有依赖项。也许您下载了开发者版本而不是稳定版本?

答案 1 :(得分:-1)

您可能必须清理Tomcat工作目录。有关更多信息,请参阅此文章