调用ajax时session过期的处理方法

前端之家收集整理的这篇文章主要介绍了调用ajax时session过期的处理方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

首先在js文件添加如下代码

$.ajaxSetup({     
        contentType:"application/x-www-form-urlencoded;charset=utf-8",complete:function(XMLHttpRequest,textStatus){  
            var sessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus");  
            if(sessionstatus=="sessionOut"){     
            	location.href = "../login.jsp?t=" + new Date().getTime();     
            }  
        }  
    });

以上代码调用ajax之前先执行。

然后在Filter中添加如下代码

HttpSession session = request.getSession(true);
	    if (request.getHeader("x-requested-with") != null && request.getHeader("x-requested-with")  
	                .equalsIgnoreCase("XMLHttpRequest") && session.getAttribute("loginID") == null){  
	    	response.setHeader("sessionstatus","sessionOut");  
	        response.getWriter().print("sessionOut");  
	    }else{
	    	chain.doFilter(req,res);
	    }

当判断session.getAttribute("loginID")为空时,证明session过期,此时complete中的代码被执行。

其中location.href中添加类似于url?xxx=随机数是为了防止JSP页面的缓存,随机数可以赋值为new Date().getTime()。

原文链接:https://www.f2er.com/ajax/164563.html

猜你在找的Ajax相关文章