解决拦截器对ajax请求的拦截实例详解


Posted in Javascript onDecember 21, 2016

解决拦截器对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;
          }
        }
      }

 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
jQuery插件 tabBox实现代码
Feb 09 Javascript
Ajax同步与异步传输的示例代码
Nov 21 Javascript
js四舍五入数学函数round使用实例
May 09 Javascript
javascript限制文本框输入值类型的方法
May 07 Javascript
延时加载JavaScript代码提高速度
Dec 27 Javascript
AngularJS模块详解及示例代码
Aug 17 Javascript
jQuery插件form-validation-engine正则表达式操作示例
Feb 09 Javascript
使用jquery判断一个元素是否含有一个指定的类(class)实例
Feb 12 Javascript
Bootstrap 网格系统布局详解
Mar 19 Javascript
jQuery.validate.js表单验证插件的使用代码详解
Oct 22 jQuery
在vue项目中使用codemirror插件实现代码编辑器功能
Aug 27 Javascript
JS页面获取 session 值,作用域和闭包学习笔记
Oct 16 Javascript
原生的强大DOM选择器querySelector介绍
Dec 21 #Javascript
懒加载实现的分页&&网站footer自适应
Dec 21 #Javascript
JS树形菜单组件Bootstrap TreeView使用方法详解
Dec 21 #Javascript
Vue.js 递归组件实现树形菜单(实例分享)
Dec 21 #Javascript
详解jQuery选择器
Dec 21 #Javascript
如何清除IE10+ input X 文本框的叉叉和密码输入框的眼睛图标
Dec 21 #Javascript
js实现可输入可选择的select下拉框
Dec 21 #Javascript
You might like
用PHP4访问Oracle815
2006/10/09 PHP
Cakephp 执行主要流程
2010/03/24 PHP
web目录下不应该存在多余的程序(安全考虑)
2012/05/09 PHP
PHP之浮点数计算比较以及取整数不准确的解决办法
2015/07/29 PHP
给大家分享几个常用的PHP函数
2017/01/15 PHP
分享5个非常有用的Laravel Blade指令
2018/05/30 PHP
js 复制或插入Html的实现方法小结
2010/05/19 Javascript
js(JavaScript)实现TAB标签切换效果的简单实例
2014/02/26 Javascript
手机开发必备技巧:javascript及CSS功能代码分享
2015/05/25 Javascript
window.onload与$(document).ready()的区别分析
2015/05/30 Javascript
javascript数组随机排序实例分析
2015/07/22 Javascript
详解JavaScript的Polymer框架中的通知交互
2015/07/29 Javascript
基于jQuery全屏焦点图左右切换插件responsiveslides
2015/09/07 Javascript
AngularJS控制器之间的数据共享及通信详解
2016/08/01 Javascript
使用jQuery实现两个div中按钮互换位置的实例代码
2017/09/21 jQuery
JavaScript实现的超简单计算器功能示例
2017/12/23 Javascript
angular使用md5,CryptoJS des加密的方法
2019/06/03 Javascript
JS扁平化输出数组的2种方法解析
2019/09/17 Javascript
微信小程序封装多张图片上传api代码实例
2019/12/30 Javascript
js实现直播点击飘心效果
2020/08/19 Javascript
详解JavaScript原型与原型链
2020/11/16 Javascript
[01:08:09]DOTA2上海特级锦标赛主赛事日 - 1 胜者组第一轮#1Liquid VS Alliance第二局
2016/03/02 DOTA
Python中MySQLdb和torndb模块对MySQL的断连问题处理
2015/11/09 Python
深入解析Python中的descriptor描述器的作用及用法
2016/06/27 Python
Python学习思维导图(必看篇)
2017/06/26 Python
python创建n行m列数组示例
2019/12/02 Python
CSS 说明横向进度条最后显示文字的实现代码
2020/11/10 HTML / CSS
HTML5如何实现元素拖拽
2016/03/11 HTML / CSS
秸秆管理实施方案
2014/03/15 职场文书
党员查摆四风问题思想汇报
2014/10/25 职场文书
机关党员四风问题个人整改措施
2014/10/26 职场文书
化工厂员工工作总结
2015/10/15 职场文书
电工实训心得体会
2016/01/14 职场文书
Python 流媒体播放器的实现(基于VLC)
2021/04/28 Python
goland 设置project gopath的操作
2021/05/06 Golang
Python 如何将integer转化为罗马数(3999以内)
2021/06/05 Python