如何有一个弹出屏幕来警告会话的时间在shiro中结束?

时间:2016-06-22 14:03:17

标签: servlets shiro

我的项目是shiro,我需要在关闭不活动超时时弹出弹出警告用户该会话将关闭。目前我已经使用Servlet容器shiro了

1 个答案:

答案 0 :(得分:0)

尝试使用javascript在计时器到期时显示弹出窗口超时存储超时时间,现在运行计时器并在计时器到期后显示弹出窗口。下面的演示代码,但你必须自定义它,它不是完整的代码。

      var timeout=<%= currentUser.getSession().getTimeout() %>;
      var starttimer=timeout-60000; //+100000000;
      var timerstep=1;//In  minutes
      var alertbefore=5;//In minutes
      var logoutUrl="logout";//Url to logout
      var militimerstep=timerstep*60*1000;
      var sessionNoExpireMessage="Session will never expire!!!";

var sess_timer=window.setInterval(updateTimer,militimerstep);
    $("#timeout_timer").html(moment.duration(parseInt(starttimer,10)).humanize(true) + " remaining ");
    if(timeout<0)
    {
        clearInterval(sess_timer);
        $("#timeout").html(sessionNoExpireMessage+ " remaining ");
    }else{
        $("#timeout").html( moment.duration(parseInt(starttimer,10)).humanize() + " remaining");
    }
    function updateTimer(){
    console.log("In timer");
   // alert(timeout);
    if(timeout<0)
        {
            clearInterval(sess_timer);
            $("#timeout").html(sessionNoExpireMessage);
            return false;
        }

        starttimer = starttimer-militimerstep;
        $("#timeout").html(moment.duration(parseInt(starttimer,10)).humanize() + " remaining");
        $("#timeout_timer").html(moment.duration(parseInt(starttimer,10)).humanize(true));
        if(starttimer<=0){
            window.location.replace("${pageContext.request.contextPath}/"+logoutUrl);
            window.location("${pageContext.request.contextPath}/"+logoutUrl);
        }
        if(starttimer<alertbefore*60*1000){
            $("#session_alert").modal();
        }
    }

    function updateSessionInfo(){
         if(timeout<0)
        {

            return false;
        }
        ajaxCount--;
        resetajaxView();
        starttimer=timeout-60000;
        $("#timeout").html(moment.duration(parseInt(starttimer,10)).humanize() + " remaining");
        $("#timeout_timer").html(moment.duration(parseInt(starttimer,10)).humanize(true));
    }