java.lang.IllegalStateException:在404上提交响应后无法转发

时间:2015-09-28 12:17:57

标签: java spring glassfish

我在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)

]]

1 个答案:

答案 0 :(得分:0)

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