27

在构建监视器时,它将监视用户在浏览器上的任何活动,例如单击按钮或在文本框上键入(而不是将鼠标悬停在文档上)。因此,如果用户长时间没有活动,会话将超时。

我们需要在没有 jQuery 或类似的东西的情况下做到这一点。我可能会使用ajax。另一端的 Java servlet 更可取。

4

2 回答 2

64

这是跟踪空闲时间的纯 JavaScript 方法,当它达到一定限制时执行一些操作,您可以相应地修改并使用

var IDLE_TIMEOUT = 60; //seconds
var _idleSecondsCounter = 0;
document.onclick = function() {
    _idleSecondsCounter = 0;
};
document.onmousemove = function() {
    _idleSecondsCounter = 0;
};
document.onkeypress = function() {
    _idleSecondsCounter = 0;
};
window.setInterval(CheckIdleTime, 1000);

function CheckIdleTime() {
    _idleSecondsCounter++;
    var oPanel = document.getElementById("SecondsUntilExpire");
    if (oPanel)
        oPanel.innerHTML = (IDLE_TIMEOUT - _idleSecondsCounter) + "";
    if (_idleSecondsCounter >= IDLE_TIMEOUT) {
        alert("Time expired!");
        document.location.href = "logout.html";
    }
}

此代码将在显示警报和重定向之前等待 60 秒,并且任何操作都将“重置”计数 - 鼠标单击、鼠标移动或按键。

它应该尽可能跨浏览器,并且直截了当。如果您将 ID 为 SecondsUntilExpire 的元素添加到页面,它还支持显示剩余时间。

参考:如何知道浏览器空闲时间?

于 2012-11-06T07:43:31.120 回答
5

您建议的方法的问题是会话将超时,即使用户正在移动鼠标或输入输入。因此,如果您将会话超时设置为 20 分钟,并且用户持续输入 21 分钟,则会话仍将超时,即使他们一直处于“活动状态”。唯一可以防止会话超时的是对服务器的新请求。

解决方案1:让服务器控制会话超时

除非您在后台发出 Ajax 请求,否则会不断更新会话,您可以在页面加载时设置 JavaScript 超时,并以这种方式提醒用户。除非您向服务器发出其他请求,否则当用户在您的页面上时,没有必要让它变得困难:

setTimeout(function () {
   alert("You've timed out baby!");
}, 1200000); // 20 minutes in millisec (modify to your session timeout)

如果用户访问另一个页面或重新加载该页面,则会话会被更新并且 JavaScript 计时器会被重置。如果用户不这样做,会话将在用户收到警报的同时超时。

解决方案2:让客户端控制会话超时

如果您希望 JavaScript 完全控制会话的持续时间,以便在用户键入、移动鼠标​​或其他任何内容时更新会话,您将不得不在后台向服务器发出 Ajax 请求,所以会话更新。(这可能是一个空的虚拟请求,只是命中服务器的东西)

然后,您必须跟踪您认为“用户活动”的所有操作(AnhSirk 在他的回答中提出了一种方法)并在发生此类事件时重置超时计时器。如果用户长时间处于非活动状态,则您必须向服务器上的页面发出 Ajax 请求,这会使会话无效,然后您可以提醒用户会话已超时。

于 2012-11-06T07:53:01.277 回答