
jsp关闭浏览器时,如何清空session 100
如何在关闭浏览器时,清空此session,因为我想控制一个用户只能一个人用。如果在关闭浏览器时调用servlet。...
如何在关闭浏览器时,清空此session,因为我想控制一个用户只能一个人用。如果在关闭浏览器时调用servlet。
展开
5个回答
展开全部
jsp关闭浏览器时,清空session的方式如下:
function window.onUnload()
{
var newWindow;
if((window.screenLeft>=10000 && window.screenTop>=10000)||event.altKey)
{ newWindow=window.open('destorys.jsp','网页名称','width=0,height=0,top=4000,left=4000');//新窗口将在视区之外打开 newWindow.opener=null; sleep(5000); newWindow.close();//新窗口关闭 }
}
function sleep(milisecond)
{ var currentDate,beginDate=new Date(); var beginHour,beginMinute,beginSecond,beginMs; var hourGaps,minuteGaps,secondGaps,msGaps,gaps; beginHour=beginDate.getHours(); beginMinute=beginDate.getMinutes(); beginSecond=beginDate.getSeconds(); beginMs=beginDate.getMilliseconds(); do { currentDate=new Date(); hourGaps=currentDate.getHours() - beginHour; minuteGaps=currentDate.getMinutes() - beginMinute; secondGaps=currentDate.getSeconds() - beginSecond; msGaps=currentDate.getMilliseconds() - beginMs; if(hourGaps<0) hourGaps+=24; //考虑进时进分进秒的特殊情况 gaps=hourGaps*3600+ minuteGaps*60+ secondGaps; gaps=gaps*1000+msGaps; }while(gaps<milisecond); }
其中红色部分为你指向清除session的JSp页面。
如下:
<%@ page contentType="text/html; charset=GBK" %> <%@ page language="java" import="java.lang.*"%> <jsp:useBean id="login" scope="page" class="com.util.Login"/> <% session.removeAttribute("username"); session.removeAttribute("userid"); session.removeAttribute("power"); session.removeAttribute("flag"); %>
这样,在每个后台页面引用一个这个JS,就可以实现了。
展开全部
如果关闭了浏览器,当前的会话已经被关闭,虽然服务器的session对象还存在,但是由于客户端已经关闭,无法再找到jsessionid,因此服务器端的session对象只能等待超时,然后被销毁,所以没必要清空session啊。
如果有用望采纳哦~
如果有用望采纳哦~
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在logon.jsp中这样写
session.removeAttribute("name");
session.invalidate();
out.print("<script>alert('用户即将退出,确定后退出该页面。');window.location.href='index.jsp'</script>");
%>
你试一下!
session.removeAttribute("name");
session.invalidate();
out.print("<script>alert('用户即将退出,确定后退出该页面。');window.location.href='index.jsp'</script>");
%>
你试一下!
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
楼下说的都挺好的,都是一些解决方案。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个问题很多人问过,虽然有办法,但是并不稳定,且总体来说意义不大。
BODY有个事件 onunload,可以在里面用Ajax向服务器发送请求,但并不总是有效,因为浏览器之间还不一样。
换个思路,如果客户端掉电了?直接强制关闭浏览器了?你这个东西就没意义了。
所以如果你打算在浏览器端做点什么,我觉得把Cookie中的jsessionid删除掉就很不错了。
但是服务器端是可以通过SessionDestory事件来得知每个session超时的,虽然可能已经是半小时之后了。
Anyway,认真思考下你的原始需求是什么,再想想合理的技术手段吧。
这有一个注销session方法,你试试看行不行:session.invalidate();
BODY有个事件 onunload,可以在里面用Ajax向服务器发送请求,但并不总是有效,因为浏览器之间还不一样。
换个思路,如果客户端掉电了?直接强制关闭浏览器了?你这个东西就没意义了。
所以如果你打算在浏览器端做点什么,我觉得把Cookie中的jsessionid删除掉就很不错了。
但是服务器端是可以通过SessionDestory事件来得知每个session超时的,虽然可能已经是半小时之后了。
Anyway,认真思考下你的原始需求是什么,再想想合理的技术手段吧。
这有一个注销session方法,你试试看行不行:session.invalidate();
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询