Ich habe mein Projekt mit Shiro und ich brauche beim Beenden des Inaktivitäts-Timeout Pop-Up-Warnung den Benutzer, dass die Sitzung geschlossen wird. Im Moment habe ich Shiro mit Servlet ContainerWie wird ein Popup-Bildschirm angezeigt, um zu warnen, dass die Zeit der Sitzung in Shiro abgelaufen ist?
-4
A
Antwort
0
versuchen Sie Javascript verwenden, um ein Popup anzeigen, sobald der Timer abläuft hier Timeout speichert Timeout-Zeit und jetzt einen Timer ausführen und ein Popup anzeigen, sobald der Timer abläuft. Demo-Code unten, aber Sie müssen es anpassen und es ist kein vollständiger Code.
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));
}