解决拦截器对ajax请求的拦截实例详解
解决拦截器对ajax请求的的拦截
拦截器配置:
publicbooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objectobj)throwsException{ //获取判定登陆的session是否存在 Stringtoken=(String)request.getSession().getAttribute("token"); StringpostId=(String)request.getSession().getAttribute("postId"); if(token==null||token==""){ StringXRequested=request.getHeader("X-Requested-With"); if("XMLHttpRequest".equals(XRequested)){ response.getWriter().write("IsAjax"); }else{ response.sendRedirect("/m-web/user/toLogin"); } returnfalse; } if(postId==null||postId==""){ StringXRequested=request.getHeader("X-Requested-With"); if("XMLHttpRequest".equals(XRequested)){ response.getWriter().write("IsAjax"); }else{ response.sendRedirect("/m-web/user/toLogin"); } returnfalse; } returntrue; }
1、判断StringXRequested=request.getHeader("X-Requested-With")的值,目的是判断是否是ajax请求。
2、response.getWriter().write("IsAjax");写出一个响应的数据给ajax,这样就可以在ajax里面做判断
判断的方式存在两种方式:
1)直接在ajax里面做判断(不建议)
success:function(data){ if(data=="IsAjax"){ window.location.href="m-web/user/toLogin" return; } }
2)改ajax源码然后在做压缩,是针对全局的方式来修改的(建议)
if(isSuccess){//ifnocontent if(status===204||s.type==="HEAD"){ statusText="nocontent"; //ifnotmodified }elseif(status===304){ statusText="notmodified"; //Ifwehavedata,let'sconvertit }else{ statusText=response.state; success=response.data; error=response.error; isSuccess=!error; //解决ajax拦截问题 varresult=responses.text; if(result.indexOf("IsAjax")>=0){ window.location.href="m-web/user/toLogin"; return; } } }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!