2

我正在尝试启动并运行我的开发环境,但由于某种原因,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 上运行安装了 1.4 兼容包和 Java 1.4.2 的 Tomcat 5.5.27。

感谢您的任何想法!

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

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

4

2 回答 2

3

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

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

更新:啊——我看到你发现是这样的:-)

不知道为什么 tomcat 不包含它的所有依赖项。也许您下载了开发人员版本而不是稳定版本?

于 2008-11-03T16:51:14.253 回答
-2

您可能需要清理 Tomcat 工作目录。

于 2009-01-26T19:40:54.247 回答