我在 GlassFish 3.0.1 中部署了一个相当简单的 Web 应用程序。我正在使用常规的基于 FORM 的身份验证,并使用 JDBC 领域保护应用程序。视图由 JSF 2 使用 Facelets 处理。
我遇到的问题是,当会话到期时,如果用户单击 ah:commandButton 或其他任何回发的内容,则会出现一个可怕的黄色页面,告诉他们存在 XML 解析错误。在日志中,我得到三个堆栈跟踪:
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 设置错误处理程序,但它从未被调用。我猜系统已经被第一个异常放弃了。现在我真的不太在乎在这种情况下我将用户发送到哪里,只要他们没有看到死亡黄页!
注意:非回发链接可以正确查找并重定向到登录页面。