session不失效,只要浏览器不关闭

本文介绍了一种通过javascript定时器定期ajax请求后台和利用cookie处理的方法,确保用户在未关闭浏览器的情况下,session状态保持有效,避免因多次访问导致的后台频繁请求。

简单实现了只要浏览器不关闭,session就不会失效的功能

 

1.javascript定时器定期ajax请求后台

2.避免用户因开多table导致频繁访问后台,利用cookie处理一下

 

function createXHR() {
	var xhr;
	if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
		xhr=new XMLHttpRequest();
	} else {// code for IE6, IE5
		xhr=new ActiveXObject("Microsoft.XMLHTTP");
	}
	return xhr;
}
function getCookie(cookieName) {
	if(document.cookie.length > 0) {
		var startIndex = document.cookie.indexOf(cookieName + '=');
		if(startIndex != -1) {		//找到cookie了
			startIndex = startIndex + cookieName.length + 1;
			var endIndex = document.cookie.indexOf(';', startIndex);
			if(endIndex = -1) {		//当前cookie为最后一个,没有';'
				endIndex = document.cookie.length;
			}
			var cookieValue = escape(document.cookie.substring(startIndex, endIndex));
			return cookieValue;
		}
		return null;
	}
	return null;
};
var MINUTES = 10;	//默认10分钟请求一次
function keepSession() {
	if(false) {		//用户没有登录直接返回
		return;
	}
	var LAST_REQUEST_TIME = 'last_equest_time';
	var lastRequestTime = new Date().getTime();
	var cookieValue = getCookie(LAST_REQUEST_TIME);
	if(!cookieValue) {	//第一次登录,还没有cookie
		document.cookie = LAST_REQUEST_TIME + '=' + lastRequestTime;
	} else {
		var intervalTime = lastRequestTime - parseInt(cookieValue);
		if(intervalTime >= 1000*60*MINUTES) {		//只要间隔大于等于规定时间才请求后台
			var xhr = createXHR();
			xhr.open('POST', 'url', true);
			xhr.send(null);
			// 更新cookie
			document.cookie = LAST_REQUEST_TIME + '=' + lastRequestTime;
		}
	}
};
setInterval(keepSession, 1000*60*MINUTES);

 

关闭浏览器是否会导致Cookie和Session数据被清除,取决于具体的配置和使用方式。 对于**Cookie**来说,如果在创建时未设置明确的过期时间(即会话Cookie),则该Cookie仅存储在浏览器的运行内存中,在浏览器关闭后会被删除。这类Cookie通常用于维护用户的登录状态,直到用户主动退出或关闭浏览器。反之,如果设置了过期时间(即持久化Cookie),即使关闭浏览器,该Cookie仍会保留在客户端的硬盘文件中,并在下次访问网站时重新生效[^2]。 而对于**Session**而言,情况有所同。Session是一种服务器端技术,通常依赖于一个名为Session ID的标识符,这个标识符一般通过Cookie的方式发送给客户端。当浏览器关闭时,与当前会话关联的Session ID Cookie如果没有设置过期时间,将随着浏览器关闭而被删除。这意味着,虽然服务器端的Session数据会立即被清除(通常会在一段时间后自动失效),但由于客户端失去了Session ID,因此无法再访问之前的Session信息[^3]。 需要注意的是,某些框架或平台(如Flask)实现Session的方式略有同。它们可能将整个Session内容加密后存储在客户端的Cookie中,而是仅仅保存一个Session ID。在这种情况下,关闭浏览器是否会影响Session数据,仍然取决于该Cookie是否设置了过期时间。如果没有设置,则浏览器关闭后,该Session信息也会丢失[^4]。 此外,现代浏览器还提供了“恢复上次会话”的功能,这可能导致即使关闭浏览器窗口,某些Cookie和Session的状态依然保留[^5]。 ### 示例代码:检查并获取Cookie ```javascript // 存储数据 document.cookie = 'name=daxiaojiuhenpi; expires=Thu, 18 Dec 2025 12:00:00 UTC; path=/'; // 读取数据 function getCookie(name) { const value = `; ${document.cookie}`; const parts = value.split(`; ${name}=`); if (parts.length === 2) return parts.pop().split(';').shift(); } const name = getCookie('name'); console.log(name); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值