1

我已经使用 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)
4

2 回答 2

1

JSF 在会话中保留一定数量的(可配置的)视图。ViewExpiredException如果您向无法再恢复的视图发布帖子,您将获得此信息,即。不再出现在该会话的视图列表中。

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

  • 会话无效/过期
  • 在应恢复的视图之后创建多个(> 视图中配置的会话数)视图
于 2011-04-06T09:18:36.893 回答
0

据我了解,这是由几件事的结合引起的:

  • 已生成包含字段内部 id 的 JSF 表单。
  • JSF 页面已更改,或整个应用程序重新部署,导致内部 id 更改。
  • 提交了具有内部 id的 JSF 表单(登录页面?),并且在 JSF 页面的id中找不到旧的内部 id。

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

于 2011-04-06T09:02:15.313 回答