GlassFish3.0.1にデプロイされた非常に単純なWebアプリケーションがあります。通常のFORMベースの認証を使用しており、JDBCレルムを使用してアプリケーションを保護しています。ビューは、Faceletsを使用してJSF2によって処理されます。
私が抱えている問題は、ユーザーがah:commandButtonまたはその他の投稿をクリックした場合にセッションが期限切れになると、XML解析エラーが発生したことを示すひどいイエローページが表示されることです。ログには、3つのスタックトレースがあります。
INFO: PWC2787: Session event listener threw exception
org.jboss.weld.context.ContextNotActiveException: WELD-001303 No active contexts for scope type javax.enterprise.context.RequestScoped
at org.jboss.weld.manager.BeanManagerImpl.getContext(BeanManagerImpl.java:679)
at org.jboss.weld.bean.proxy.ClientProxyMethodHandler.getProxiedInstance(ClientProxyMethodHandler.java:138)
at org.jboss.weld.bean.proxy.ClientProxyMethodHandler.invoke(ClientProxyMethodHandler.java:100)
<snip>
WARNING: ApplicationDispatcher[/core] PWC1231: Servlet.service() for servlet Faces Servlet threw exception
javax.faces.application.ViewExpiredException: viewId:/login.xhtml - View /login.xhtml could not be restored.
at com.sun.faces.lifecycle.RestoreViewPhase.execute(RestoreViewPhase.java:212)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:110)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
<snip>
WARNING: Unexpected error forwarding or redirecting to login page
javax.servlet.ServletException: viewId:/login.xhtml - View /login.xhtml could not be restored.
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:325)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1523)
at org.apache.catalina.core.ApplicationDispatcher.doInvoke(ApplicationDispatcher.java:822)
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:684)
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:517)
<snip>
この問題に対処するためのクリーンでシンプルな方法を見つけることができないようです。web.xmlでViewExpiredExceptionのエラーハンドラーを設定しようとしましたが、呼び出されませんでした。システムは最初の例外ですでに諦めていると思います。今のところ、ユーザーが死のイエローページを表示しない限り、この状況でユーザーをどこに送るかはあまり気にしません。
注:ポストバック以外のリンクは、ログインページを正しく検索してリダイレクトします。