0

我正在尝试在 Tomcat (7.0.12) 中部署 cocoon (2.1.11) (我知道我可以独立运行 cocoon 并且已经成功地做到了,但我试图更好地了解整个 Web 应用程序环境)我已经构建了cocoon.war 文件,将其复制到 tomcat/webapps 目录并启动 tomcat。

我查阅过的所有网页都明确表示这就是所需要的。我可以看到 .war 文件被解压缩到一个 cocoon 子目录中,并且 cocoon 显示为应用程序之一。但是当我浏览到这个 URL 时:

http://localhost:8080/cocoon

我得到这个Java回溯:

org.apache.cocoon.ResourceNotFoundException: No pipeline matched request: index.html
    at org.apache.cocoon.components.treeprocessor.sitemap.PipelineNode.invoke(PipelineNode.java:149)
    at org.apache.cocoon.components.treeprocessor.AbstractParentProcessingNode.invokeNodes(AbstractParentProcessingNode.java:69)
    at org.apache.cocoon.components.treeprocessor.sitemap.PipelinesNode.invoke(PipelinesNode.java:93)
    at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:235)
    at org.apache.cocoon.components.treeprocessor.ConcreteTreeProcessor.process(ConcreteTreeProcessor.java:177)
    at org.apache.cocoon.components.treeprocessor.TreeProcessor.process(TreeProcessor.java:254)
    at org.apache.cocoon.Cocoon.process(Cocoon.java:699)
    at org.apache.cocoon.servlet.CocoonServlet.service(CocoonServlet.java:1154)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:395)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:250)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
    at java.lang.Thread.run(Thread.java:636)

谁能帮我理解为什么?

4

2 回答 2

2

我知道这已经有多年历史了,我刚刚在 tomcat 7.0.29 部署中使用了http://www.xml.com/lpt/a/1178 cocoon-soap.war 并且需要修改 sitemap.xmap 以包含

 <map:match pattern="index.html"> 

以及以下内容:

<map:match pattern=""> 
 <map:generate src="index.html"/>
 <map:serialize/>
</map:match>
于 2012-07-17T12:04:57.817 回答
1

发生此错误通常是因为您的站点地图设置不正确。您是否在站点地图中声明了通用 .html 管道。

于 2011-10-20T20:36:27.380 回答