0

我想在浏览器上打开网页时保持会话活跃,即使我很长时间没有触摸它,这就是我尝试做的事情:

  1. 在服务器端(tomcat),会话超时设置为 8 分钟。
  2. main jsp 生成一个html。在这个 html 中,我使用 timer & ajaxheartbeat.jsp每 3 分钟调用一次,并将初始会话 id 的值传递给它。
  3. heartbeat.jsp中,我转储了session.getId()的值和初始会话 ID。

【执行结果时间线】:

  • 10:00我打开页面——主jsp程序生成客户端html
  • 10:03 heartbeat.jsp调用 -- session.getId()= 初始会话 ID
  • 10:06 heartbeat.jsp调用 -- session.getId()= 初始会话 ID
  • 10:09 heartbeat.jsp调用 -- session.getId()<> 初始会话 ID

初始会话 id 的最后访问时间为10:06,因此初始会话 id 的超时时间应为10:14。但是为什么在10:09,session.getId()得到另一个新的 id 呢?

似乎前 2 个调用没有在服务器端重置初始会话的超时计数器。我在 IE 和 Firefox 中都对此进行了测试,它们的结果相同

我怎样才能让会话永远活着?

[主要的jsp代码段]:

<script type="text/javascript" src="/fp/js/prototype.js"></script>
<script type="text/javascript" src="/fp/js/jquery.min.js"></script>
<script type="text/javascript" src="/fp/js/jquery.roundabout.min.js"></script>
<script type="text/javascript">
  function heartbeats(sid) {
    var url = '/test/heartbeat.jsp' + '?rn=' + Math.random() +'&mysid='+sid;
    var myAjax = new Ajax.Request(url,{
      method: 'get',
      onFailure:  function(request) {
        alert("connect problem, can't do heartbeat!");
      },
      onSuccess: function(response) {
        if (response.responseText.indexOf("timeout") != -1) {
          alert("original session is expired");
        }
      }
    });
  }
  function init_heartbeat(sid) {
    new PeriodicalExecuter(function(startHeart){heartbeats(sid);}, 60*3);
  }
  init_heartbeat("<%=session.getId()%>");
</script>

[heartbeat.jsp 代码段]:

  String server_sid = (String)session.getId();  
  String client_sid = 
    request.getParameter("mysid")==null?"":(String)request.getParameter("mysid");
  java.util.Calendar calendar = java.util.Calendar.getInstance();
  File lf = new File("/usr/tmp/hb.log");    
  try {
    lf.println( "servre sid = "+server_sid);
    lf.println( "client sid = "+client_sid);
    lf.println( "~~~~~");
    lf.close();
  } catch(Exception e)  {
    out.print(e);
  }
  if(!server_sid.equals(client_sid))
    out.print("timeout");
4

1 回答 1

0

我通过对空白页面的定时后台 jquery ajax 调用解决了这个保持会话活动的问题 - 然后服务器在后台每 x 秒接收一个请求。Jquery 可能更简单?

于 2011-03-03T18:17:37.317 回答