javax.servlet.ServletException - как я могу добраться до причины? - PullRequest
1 голос
/ 01 апреля 2010

Я получаю очень странную ошибку при открытии одной из страниц в моем веб-приложении. Приложение построено на Seam 2.2 и использует JSF (RichFaces) на уровне представления. Я запускаю его на Tomcat 6.

В журналах все выглядит нормально - каждая следующая фаза JSF выполняется нормально, и после последней наступает момент, когда запрос начинает обработку страницы отладки SEAM ...

И это трассировка стека, которую я вижу на странице отладки (ничего не регистрируется):

Исключение при обработке запроса: Вызывается javax.servlet.ServletException с сообщением: «При выполнении сервлета возникло исключение»

org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:313)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:83)
org.jboss.seam.web.IdentityFilter.doFilter(IdentityFilter.java:40)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.MultipartFilter.doFilter(MultipartFilter.java:90)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.ExceptionFilter.doFilter(ExceptionFilter.java:64)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.RedirectFilter.doFilter(RedirectFilter.java:45)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.ajax4jsf.webapp.BaseXMLFilter.doXmlFilter(BaseXMLFilter.java:178)
org.ajax4jsf.webapp.BaseFilter.handleRequest(BaseFilter.java:290)
org.ajax4jsf.webapp.BaseFilter.processUploadsAndHandleRequest(BaseFilter.java:388)
org.ajax4jsf.webapp.BaseFilter.doFilter(BaseFilter.java:515)
org.jboss.seam.web.Ajax4jsfFilter.doFilter(Ajax4jsfFilter.java:56)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.LoggingFilter.doFilter(LoggingFilter.java:60)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.web.HotDeployFilter.doFilter(HotDeployFilter.java:53)
org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
org.jboss.seam.servlet.SeamFilter.doFilter(SeamFilter.java:158)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
pl.mgibowski.alterium.util.LoggingFilter.doFilter(LoggingFilter.java:18)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:465)
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852)
org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
java.lang.Thread.run(Thread.java:619)

Исключение без причины ...

Я пытался перехватить исключение с помощью моего пользовательского фильтра (LoggingFilter.java, который вы видите на трассировке), используя этот код:

try {
            filterChain.doFilter(servletRequest, servletResponse);
        }
        catch (Throwable e) {
            e.printStackTrace();
            System.out.println("Stack trace:");
            System.out.println(e.getStackTrace());
            System.out.println("Cause:");
            System.out.println(e.getCause());
        }

Но это ничего не улавливает, строка 18 из трассировки стека - это:

filterChain.doFilter(servletRequest, servletResponse);

блок try не получает ничего.

У кого-нибудь есть идеи о том, как я могу приблизиться к реальному делу?

1 Ответ

1 голос
/ 01 апреля 2010

Хорошо, я изменил порядок, в котором мой фильтр и мое сопоставление фильтров применяются в web.xml, и теперь мой фильтр перехватывает реальное исключение.

...