2015-09-28 2 views
0

У меня есть Spring 4.0.1 Java Web Application, развернутое на Glassfish 4.0. Всякий раз, когда возникает ошибка 404, в журналах есть исключение. Страница ошибки отображается правильно (это простой, простой html). Несмотря на то, что приложение работает нормально, я хотел бы избавиться от этого исключения. Это исключение НЕ выбрасывается при запуске localy на tomcat.java.lang.IllegalStateException: Не удается переслать после ответа на 404

Ошибка страницы конфигурации в 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] [[ 



[email protected]: 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) 

]] 

ответ

0

Это исключение часто происходит всякий раз, когда вы пытаетесь сделать вперед или редирект после уже сделали один раз. Основываясь на моем опыте, у вас, вероятно, есть где-то в вашем коде инструкция if с переадресацией, а затем другая переадресация/перенаправление. Если это так, просто добавьте предложение else перед вторым перенаправлением. Если это не проблема, вы можете отправить еще какой-нибудь код?

+0

Спасибо, но я уже прочитал тысячи таких ответов;) Ничего подобного в любом месте моего кода и ошибки возникает на странице, не найденной ошибкой, которая обрабатывается весной. – Please

+0

Кроме того, я не знаю, какой код я должен опубликовать. Трассировка стека не указывает на какое-либо пятно, в частности, но «Обработка ErrorPage [errorCode = 404, location =/pages/404.html]». – Please

+0

Вы используете IDE? Попробуйте отладить его. Таким образом, вы можете увидеть, где именно выбрано исключение, и затем вы можете опубликовать это здесь. – Aurasphere

Смежные вопросы