解决拦截器对ajax请求的拦截实例详解
2016-12-21 17:29
711 查看
解决拦截器对ajax请求的的拦截
拦截器配置:
public boolean preHandle(HttpServletRequest request, HttpServletResponse response,Object obj) throws Exception { //获取判定登陆的session是否存在 String token = (String) request.getSession().getAttribute("token"); String postId = (String) request.getSession().getAttribute("postId"); if(token == null || token == ""){ String XRequested =request.getHeader("X-Requested-With"); if("XMLHttpRequest".equals(XRequested)){ response.getWriter().write("IsAjax"); }else{ response.sendRedirect("/m-web/user/toLogin"); } return false; } if(postId == null || postId == ""){ String XRequested =request.getHeader("X-Requested-With"); if("XMLHttpRequest".equals(XRequested)){ response.getWriter().write("IsAjax"); }else{ response.sendRedirect("/m-web/user/toLogin"); } return false; } return true; }
1、判断 String XRequested =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 ) {// if no content if ( status === 204 || s.type === "HEAD" ) { statusText = "nocontent"; // if not modified } else if ( status === 304 ) { statusText = "notmodified"; // If we have data, let's convert it } else { statusText = response.state; success = response.data; error = response.error; isSuccess = !error; //解决ajax拦截问题 var result = responses.text; if(result.indexOf("IsAjax")>=0){ window.location.href="m-web/user/toLogin"; return; } } }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
- JS 拦截全局ajax请求实例解析
- Ajax请求响应中用window.open打开新窗口被拦截的解决方法
- Node.js服务器环境下使用Mock.js拦截AJAX请求的教程
- ajax回调打开新窗体防止浏览器拦截有效方法
- 在Java的Struts中判断是否调用AJAX及用拦截器对其优化
- ajax请求成功后新开窗口window.open()被拦截解决方法
- jquery ajax 向后台传递数组参数示例
- jquery中ajax使用error调试错误的方法
- JQuery的Ajax请求实现局部刷新的简单实例
- jquery的ajax()函数传值中文乱码解决方法介绍
- jQuery Ajax异步处理Json数据详解
- JQuery处理json与ajax返回JSON实例代码
- Jquery中ajax方法data参数的用法小结
相关文章推荐
- 解决拦截器对ajax请求的的拦截
- 实例详解Android Webview拦截ajax请求
- Struts2 拦截器处理普通Http请求和Ajax请求时拦截配置
- AJAX 跨域请求 – JSONP的使用,PHP实例详解
- Struts2 拦截器处理同步(普通Http)请求和异步(post,ajax)请求时拦截配置
- Struts2拦截器的应用:未登录用户拦截(同时拦截ajax请求)
- 用反向代理nginx proxy_pass配置解决ie8 ajax请求被拦截问题 ie8用nginx代理实现跨域请求访问 nginx405正向代理request_uri
- 【jquery】ajax 请求成功后新开窗口被拦截解决方法
- 实例详解jQuery Mockjax 插件模拟 Ajax 请求
- Ajax请求成功后新开窗口window.open()被拦截解决方法
- ajax请求响应中用window.open打开新窗口会被浏览器拦截的解决方式
- JS 拦截全局ajax请求实例解析
- Ajax请求Session超时的解决办法:拦截器 + 封装jquery的post方法
- ajax请求成功后新开窗口window.open()被拦截解决方法
- IE中ajax+jsp登录界面,由于缓存导致jsp过滤器与ajax请求被拦截的问题和解决
- Struts2 拦截器处理普通Http请求和Ajax请求时拦截配置
- Struts 通过拦截器实现登录后跳转到登录前页面 处理普通Http请求和Ajax请求时拦截配置
- Ajax请求Session超时的解决办法:拦截器 + 封装jquery的post方法
- ajax请求session过期失效被拦截的解决
- Ajax请求响应中用window.open打开新窗口被拦截的解决方法