ajax请求时session已过期处理方案

前端之家收集整理的这篇文章主要介绍了ajax请求时session已过期处理方案前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
web系统中常常使用拦截器或过滤器实现权限拦截,判断用户是否登陆,若未登陆,跳转到登陆页,但当浏览器发的是ajax请求时,浏览器不会正常跳转,而是返回登陆页的HTML源码给ajax回调函数(当跳转的登陆页跨域时,会出现302错误),解决方案如下: @H_502_2@
@H_502_2@
前端: @H_502_2@
//如果session超时或未登陆,则跳转到登陆页 @H_502_2@
@H_502_2@
 $(document).ajaxComplete(function(event,request,settings){
  var data=request.responseJSON;
  if(data.ret!=null&&data.ret==302)//根据服务器端返回的数据判断
  {
           window.location=data.redirectUrl;
  }
 });
@H_502_2@ @H_502_2@
服务器: @H_502_2@
1 @H_502_2@
2 @H_502_2@
3 @H_502_2@
4 @H_502_2@
5 @H_502_2@
6 @H_502_2@
7 @H_502_2@
8 @H_502_2@
9 @H_502_2@
@RequestMapping (value = "/nologin" ) @H_502_2@
public void login(HttpServletRequest request,HttpServletResponse response,Model model) throws Exception { @H_502_2@
if (request.getHeader( "X-Requested-With" )!= null &&request.getHeader( "X-Requested-With" ).equals( "XMLHttpRequest" )) @H_502_2@
{ @H_502_2@
response.getWriter().write({ "ret" : 302 , "msg" : " " , "redirectUrl" :“”}"); @H_502_2@
} else { @H_502_2@
response.sendRedirect(applicationProps.getProperty( "oauth.ucenter.url" )); @H_502_2@
} @H_502_2@
} @H_502_2@ @H_502_2@
@H_502_2@ @H_502_2@ @H_502_2@ @H_502_2@
服务端根据请求头X-Requested-With是否有值且是否是XMLHttpRequest(表示ajax请求)来判断是否是ajax请求,如果是则返回json数据,若不是则正常跳转; @H_502_2@
@H_502_2@
前端为ajax请求添加的全局的Complete方法,ajax请求完成时触发(不管请求是否成功),其中var data=request.responseJSON;是获取服务器返回的Jason数据,根据json数据完成跳转。 @H_502_2@ @H_502_2@

猜你在找的Ajax相关文章