javax.faces.application.ViewExpiredException:无法恢复视图

时间:2011-04-06 08:38:48

标签: java jsf filter viewexpiredexception prettyfaces

我使用jsf,prettyfaces和hibernate创建了这个网页 我环顾四周,大多数人都说这个错误是因为缓存 他们中的大多数人在登录,注销并尝试登录后发现此错误 但我在登录时发现此错误,当我尝试导航到任何其他页面时,我点击的任何链接都会产生此错误

更难的是每次都不会发生这种错误 有时当我尝试重新启动服务器,登录回来时,每个工作都很好 但有时当再次出现此错误时,我尝试重新启动服务器并尝试重新登录。仍然会出现相同的错误

javax.faces.application.ViewExpiredException: viewId:/ePortfolio.jsf - View /ePortfolio.jsf 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)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:312)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:79)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at com.ocpsoft.pretty.PrettyFilter.doFilter(PrettyFilter.java:112)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:470)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Unknown Source)

2 个答案:

答案 0 :(得分:1)

JSF在会话中保留(可配置的)视图数量。如果你对一个无法恢复的视图发帖,你会得到这个ViewExpiredException,即。在该会话的观看列表中不再出现。

这可能有多种原因。我现在能想到的两种可能的情况是:

  • 会话无效/已过期
  • 在应该恢复的视图之后创建多个(在视图中配置的会话数)视图

答案 1 :(得分:0)

据我所知,这是由几件事的结合引起的:

  • 已生成包含字段内部标识的JSF表单。
  • JSF页面已更改,或者整个应用程序已重新部署,导致内部ID发生变化。
  • 提交了内部ID的JSF表单(登录页面?), new 内部ID 用于JSF页面的em> ids。

在尝试再次提交之前,您必须在浏览器中刷新页面(获取新ID)。