Прежде всего, реализация Mojarra непреднамеренно поменяла значение этих параметров контекста.Так что если у вас сложилось впечатление, что описание является совершенно другим, чем то, что подразумевает буквальное имя параметра контекста, то это действительно так.
com.sun.faces.numberOfLogicalViews
Этов основном на основе запроса GET.Каждый запрос GET создает новое представление в сеансе.
Чтобы поэкспериментировать с ним, установите для него значение 3, запустите новый сеанс браузера и откройте 4 разные вкладки браузера (независимо от URL; могут быть одинаковыми, могут отличаться) по очереди, а затем вернитесь назад.на 1-й вкладке и отправьте форму там.Вы получите ViewExpiredException
, потому что это представление было вытолкнуто из карты LRU (наименьшее недавно использованное) для представлений в сеансе.Этого не произойдет, если вы открыли максимум 3 вкладки.
При значении по умолчанию 15 это редкая проблема в реальном мире.Если ваше веб-приложение действительно предназначено для использования таким образом (например, сайт социальной сети / сообщества, который приглашает к открытию на нескольких вкладках, таких как дискуссионный форум или вопросы и ответы), то вы можете рассмотреть возможность сохранения состояния клиента на стороне вместо увеличения значения по умолчанию.,С сохранением состояния на стороне клиента вы никогда не столкнетесь с этим исключением.В качестве альтернативы можно использовать OmniFaces <o:enableRestorableView>
в сочетании с компонентом в области запроса и параметрами запроса или компонентом в области просмотра, который проверяет (пост) конструкцию, нужно ли восстанавливать его собственное состояние.Опять же, другой альтернативой является переход к без сохранения состояния с <f:view transient="true">
, таким образом, представления больше не сохраняются, но вы больше не можете использовать bean-объекты видимости.
Эквивалент MyFaces равен org.apache.myfaces.NUMBER_OF_VIEWS_IN_SESSION
по умолчанию 20.
com.sun.faces.numberOfViewsInSession
Это в основном синхронный (не ajax!) Запрос POST.Каждый синхронный POST-запрос создает новое логическое представление.Все они хранятся на основе физического представления, например, Map<PhysicalView, Map<LogicalView, ViewState>>
.Таким образом, с максимум 15 физическими представлениями и максимум 15 логическими представлениями вы можете теоретически иметь 15 * 15 = 225 представлений в сеансе.
Чтобы поэкспериментировать с этим, установите для него значение 3, откройте представление ссинхронную форму, отправьте ее 4 раза, затем нажмите кнопку браузера назад 4 раза, а затем снова отправьте форму.Вы получите ViewExpiredException
, потому что это представление было выдвинуто из карты LRU (наименьшее из недавно использованных) для логических представлений.Этого не произойдет, если вы вернетесь максимум 3 раза, а затем повторно отправите его.
Обратите внимание, что отправка ajax повторно использует то же логическое представление (вы можете подтвердить это, увидев точно такое же значение javax.faces.ViewState
, возвращаемое в обратных передачах ajax).В любом случае, в браузере нет кнопки «Назад».Кнопка возврата браузера только возвращает вас к предыдущему синхронному запросу, поэтому не имеет смысла сохранять все эти обратные передачи ajax в виде логических представлений в сеансе.
При значении по умолчанию 15 и текущем трендеФормы только для ajax и отключенный кеш на динамических страницах, это очень редкая проблема в реальном мире.Правильно оформленные формы не должны вызывать нажатие кнопки «Назад» браузера.Вместо этого они должны при успешной отправке перенаправить в целевое представление, а при неудаче просто повторно отобразить ту же форму с ошибками проверки.См. Также советы Как ориентироваться в JSF?Как сделать так, чтобы URL отражал текущую страницу (а не предыдущую) .Кроме того, кеш более чем часто отключается на динамических страницах, поэтому кнопка «Назад» в основном даст вам совершенно новый вид назад.См. Также Избегайте кнопки возврата в веб-приложении JSF .Если это также относится к вашему приложению, то вы можете безопасно установить значение 1.
Изначально MyFaces не имело аналога для этого, и это также считается физическим представлением в сеансе.В версии 2.0.6 было введено org.apache.myfaces.NUMBER_OF_SEQUENTIAL_VIEWS_IN_SESSION
с аналогичной целью, но с другой реализацией и по умолчанию отключено.
См. Также: