【问题标题】:java.lang.IllegalStateException: Cannot forward after response has been committed on 404java.lang.IllegalStateException:在 404 上提交响应后无法转发
【发布时间】:2015-09-28 12:17:57
【问题描述】:

我在 Glassfish 4.0 上部署了 Spring 4.0.1 Java Web 应用程序。每当发生 404 错误时,日志中都会引发异常。错误页面正确显示(它是简单的 html)。即使应用程序运行良好,我也想摆脱这个异常。在 tomcat 上运行 localy 时不会抛出此异常。

web.xml 中的错误页面配置:

<error-page>
    <error-code>404</error-code>
    <location>/pages/404.html</location>
</error-page>

<error-page>
    <exception-type>java.lang.Throwable</exception-type>
    <location>/pages/500.html</location>
</error-page>

位置指向资源中的 html 文件。

全栈:

[2015-09-28T12:11:39.092+0200] [glassfish 4.0] [WARNING] [] [javax.enterprise.web] [tid: _ThreadID=1126 _ThreadName=http-listener-3(28)] [timeMillis: 1443435099092] [levelValue: 900] [[



org.apache.catalina.core.StandardHostValve@bd9e709: Exception Processing ErrorPage[errorCode=404, location=/pages/404.html]

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.IllegalStateException: Cannot forward after response has been committed

at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:973)

at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:852)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)

at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)

at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)

at org.apache.catalina.core.ApplicationDispatcher.doInvoke(ApplicationDispatcher.java:875)

at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:739)

at org.apache.catalina.core.ApplicationDispatcher.doInclude(ApplicationDispatcher.java:695)

at org.apache.catalina.core.ApplicationDispatcher.include(ApplicationDispatcher.java:626)

at org.apache.catalina.core.StandardHostValve.custom(StandardHostValve.java:492)

at org.apache.catalina.core.StandardHostValve.dispatchToErrorPage(StandardHostValve.java:691)

at org.apache.catalina.core.StandardHostValve.status(StandardHostValve.java:376)

at org.apache.catalina.core.StandardHostValve.postInvoke(StandardHostValve.java:234)

at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:359)

at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:260)

at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:188)

at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:191)

at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:168)

at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:189)

at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114)

at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)

at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:838)

at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113)

at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115)

at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55)

at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135)

at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:564)

at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544)

at java.lang.Thread.run(Thread.java:745)

Caused by: java.lang.IllegalStateException: Cannot forward after response has been committed

at org.apache.catalina.core.ApplicationDispatcher.doDispatch(ApplicationDispatcher.java:448)

at org.apache.catalina.core.ApplicationDispatcher.dispatch(ApplicationDispatcher.java:428)

at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:378)

at org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler.handleRequest(DefaultServletHttpRequestHandler.java:122)

at org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:51)

at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:945)

at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:876)

at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:961)

... 33 more

----- Root Cause -----

java.lang.IllegalStateException: Cannot forward after response has been committed

at org.apache.catalina.core.ApplicationDispatcher.doDispatch(ApplicationDispatcher.java:448)

at org.apache.catalina.core.ApplicationDispatcher.dispatch(ApplicationDispatcher.java:428)

at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:378)

at org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler.handleRequest(DefaultServletHttpRequestHandler.java:122)

at org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:51)

at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:945)

at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:876)

at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:961)

at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:852)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)

at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)

at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)

at org.apache.catalina.core.ApplicationDispatcher.doInvoke(ApplicationDispatcher.java:875)

at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:739)

at org.apache.catalina.core.ApplicationDispatcher.doInclude(ApplicationDispatcher.java:695)

at org.apache.catalina.core.ApplicationDispatcher.include(ApplicationDispatcher.java:626)

at org.apache.catalina.core.StandardHostValve.custom(StandardHostValve.java:492)

at org.apache.catalina.core.StandardHostValve.dispatchToErrorPage(StandardHostValve.java:691)

at org.apache.catalina.core.StandardHostValve.status(StandardHostValve.java:376)

at org.apache.catalina.core.StandardHostValve.postInvoke(StandardHostValve.java:234)

at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:359)

at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:260)

at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:188)

at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:191)

at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:168)

at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:189)

at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136)

at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114)

at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)

at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:838)

at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113)

at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115)

at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55)

at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135)

at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:564)

at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544)

at java.lang.Thread.run(Thread.java:745)

]]

【问题讨论】:

  • 我在 Payara (glassfish) 上运行的 jsf 2.3 应用程序遇到了同样的问题。我使用 primefaces 6.2 和 omnifaces 2.7

标签: java spring glassfish


【解决方案1】:

当您尝试执行一次转发或重定向后,通常会发生此异常。根据我的经验,您的代码中可能有一个 if 指令,带有重定向,然后是另一个转发/重定向。如果是这种情况,只需在第二个重定向之前添加一个 else 子句。如果这不是问题,请您发布更多代码吗?

【讨论】:

  • 谢谢,但我已经阅读了数千个这样的答案;)在我的代码中没有任何类似的地方,并且错误发生在由 spring 处理的 page not found 错误上。
  • 另外,我真的不知道我应该发布什么代码。堆栈跟踪没有特别指向任何位置,而是“处理 ErrorPage[errorCode=404, location=/pages/404.html]”。
  • 您使用的是 IDE 吗?尝试使用它进行调试。因此,您可以查看究竟是哪里引发了异常,然后您可以在此处发布。
猜你喜欢
  • 2014-04-27
  • 2015-01-27
  • 2013-09-15
  • 1970-01-01
  • 2011-12-18
  • 1970-01-01
  • 2014-05-09
  • 2016-03-08
  • 2016-06-22
相关资源
最近更新 更多