Если я не понял, какова ваша реальная цель, то вам нужен своего рода таймер, который автоматически расширяет каждую клиентскую часть пользовательского сеанса, последовательно переопределяя время окончания сеанса страницы сервера по умолчанию (обычно 30 минут, только для подробностей, потому что я понял что скрипт «рендерится» каждые 30 секунд, если пользователь активен на странице).
Если так, то до JSF я всегда расширял неактивные пользовательские сессии через подпольный Javascript, поэтому я буду использовать его и в вашем случае. Практически вы можете создать простой слушатель страниц в Javascript, начиная с:
window.setInterval( expression , msecIntervalTiming );
«выражение» может быть вызванной функцией, в которой вы вызываете некоторую фиктивную JSF, необходимую для поддержания сеанса без перезагрузки текущей страницы, которую посетил пользователь, в прошлом я использовал стандартный frame или iframe для выполнения http-вызовов, теперь с XHR / Ajax тоже проще.
Пример Javascript:
var timerID = null;
function simplePageListener() { // invoked by some user event denoting his absence status
// here goes all events and logic you need and know for firing the poller...
if (timerID == null) // avoid duplicates
timerID = window.setInterval( "window.startPoller()", msecIntervalTiming );
}
//...
function pollerStart() {
// make iframe or ajax/xhr requests
}
function pollerStop() {
// make action like page reloading or other needings
}
//...
function triggeredCleanTimer(timer) { // invoked by some user event denoting his active status
clearTimeout(timer); // it can be also the global variable "timerID"
timerID = null;
}
В основном вы используете «timerID» в качестве глобальной ссылки для отслеживания статуса слушателя, поэтому, когда вам нужно активировать «autoextension», вы назначаете ему setInterval. Вместо этого, когда пользователь возвращается на страницу (вызванную каким-либо известным вам событием), вы сбрасываете тайм-аут, останавливая опрос слушателя. Приведенный выше пример, очевидно, подразумевает, что пользователь, когда возвращается, должен перезагрузить страницу вручную .
Однако в вашем конкретном случае я не буду вмешиваться в JavaScript, автоматически генерируемый фреймворком Icefaces. Даже если для ipothesys вы можете периодически моделировать некоторые пользовательские события на невидимых элементах ввода (стиль установлен на «visibility: hidden», абсолютно не на «display: none» ), это приводит к тому, что событие Icefaces не будет останови его и заставь себя работать непрерывно
Такие элементы, как на котором вы можете периодически вызывать вызов события click по
document.forms["YourDummyForm"]["invisivleButton"].click();
Для использования, смотрите старые великие JS документы Devedge Online: -)
http://devedge -temp.mozilla.org / библиотека / руководства / 2000 / JavaScript / 1,3 / ссылка / window.html # 1203669