javax.faces.application.ViewExpiredException: представление не может быть восстановлено - PullRequest
1 голос
/ 06 апреля 2011

я создал эту веб-страницу, используя 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 ]

1 голос
/ 06 апреля 2011

JSF сохраняет (настраиваемое) количество просмотров в сеансе.Вы получите это ViewExpiredException, если сделаете сообщение для представления, которое больше не может быть восстановлено, т.е.больше не присутствует в списке представлений для этого сеанса.

Для этого может быть несколько причин.Два возможных сценария, о которых я могу думать прямо сейчас:

  • Сессия недействительна / истекла
  • Множество (> настроенное количество сеансов в просмотре), создаваемых после того, которое должно быть восстановлено
0 голосов
/ 06 апреля 2011

Насколько я понимаю, это вызвано сочетанием нескольких вещей:

  • Сгенерирована JSF-форма, содержащая внутренний идентификатор поля.
  • Страница JSFбыл изменен, или все приложение повторно развернуто, что привело к изменению внутренних идентификаторов.
  • Отправляется JSF-форма с внутренним идентификатором old (страница входа?) и old внутренний идентификатор не может быть найден в новых идентификаторах для JSF-страницы.

Вы должны обновить страницу в браузере (получение новых идентификаторов)прежде чем пытаться отправить снова.

...