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

世上最好的保鲜就是不断进步,让自己成为一个更好和更值得爱的人。早安!不要去争取属于别人的东西,否则,费的力越多,得到的越少。早安!

解决拦截器对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.rel="nofollow noopener noreferrer" 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.rel="nofollow noopener noreferrer" href="m-web/user/toLogin";
            return;
          }
        }
      }

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

以上就是解决拦截器对ajax请求的拦截实例详解。览前贤思己任铁杵磨针只求前程似锦,念亲情感师恩悬梁刺股但愿无愧我心。更多关于解决拦截器对ajax请求的拦截实例详解请关注haodaima.com其它相关文章!

您可能有感兴趣的文章
微信小程序wx.request拦截器使用详解

axios使用拦截器统一处理所有的http请求的方法

axios全局请求参数设置,请求及返回拦截器的方法

微信小程序之页面拦截器的示例代码

详解Angular.js中$http拦截器的介绍及使用