angular中的http拦截器Interceptors的实现

在angularJs中增加一个对全局的http请求统一做出处理的api--interceptors

Interceptors 有两个处理时机,分别是:

  • 其它程序代码执行 HTTP 请求之后,在实际从浏览器发出请求之前,即处理请求
  • 得到请求的响应之后,在交给其它程序代码处理之前,即处理请求的响应

其引用场景包括

  • 全局处理错误
  • 统一进行身份验证一类的处理
  • 对所有发出去的请求进行预处理
  • 对所有收到的响应进行预处理等等

使用实例如下:

rush:js;"> commonService.config(['$httpProvider',function($httpProvider){
//$httpProvider.defaults.headers.common = {'X-Auth-Token': $.cookie('x_auth_token'),'Content-Type':'application/json;charset=UTF-8'};

//<a href="https://www.jb51.cc/tag/tianjia/" target="_blank" class="keywords">添加</a><a href="https://www.jb51.cc/tag/lanjie/" target="_blank" class="keywords">拦截</a>器;

$httpProvider.interceptors.push(function ($q) {

  return {

    request: function (obj) {


      $('.loading').show();

      obj.headers['X-Auth-Token'] = $.cookie('x_auth_token');

      if(!obj.headers['Content-Type'])

        obj.headers['Content-Type'] = 'application/json;charset=UTF-8';



      var url,p<a href="https://www.jb51.cc/tag/ara/" target="_blank" class="keywords">ara</a>ms,method;



      //加盟店请求

      mylog('jiamengdian::',sessionStorage.getItem("chainStorefrnId"));

      if(sessionStorage.getItem("chainStorefrnId")){

        //<a href="https://www.jb51.cc/tag/zengjia/" target="_blank" class="keywords">增加</a>操作人id,name和storeid等信息

        //操作人姓名

        var operatorName = $.cookie("userType") == "employee" ? decodeURI($.cookie("username")) : decodeURI($.cookie("frnName"));

        //操作人id

        var operatorId = $.cookie("userId");

        //加盟店id

        var operatorStoreId = $.cookie("frnId");

        if (obj.method) {

          method = obj.method.toLowerCase();

        } else {

          method = "get";

        }

        //处理url,区分首次授信还是追加授信

        var flag_url = sessionStorage.getItem('chainStoreFlag');

        mylog('flag_url',flag_url);

        if(flag_url && flag_url == "f<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tcredit"){



          //提交需要<a href="https://www.jb51.cc/tag/jiashang/" target="_blank" class="keywords">加上</a>加盟店标识

          if(obj.url.indexOf("f<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tcredit/createPerF<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tCredit")!=-1){

            //标识个人提交

            obj.url = obj.url.replace('f<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tcredit/createPerF<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tCredit','f<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tcredit/perF<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tCreditByFranchisee');

          }

          else if(obj.url.indexOf("f<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tcredit/createBusiF<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tCredit")!=-1){

            //标识企业提交

            obj.url = obj.url.replace('f<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tcredit/createBusiF<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tCredit','f<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tcredit/createBusiF<a href="https://www.jb51.cc/tag/irs/" target="_blank" class="keywords">irs</a>tCreditByFranchisee');

          }


          } else {

            url = obj.url + "?creditType=1&operatorName=" + operatorName + "&operatorId=" + operatorId + "&operatorStoreId=" + operatorStoreId;

           }

        }

      return obj;

    },response: function (res) {

      $(".loading").hide();

      return res;

    },responseError: function (err) {

      $(".loading").hide();

      return $q.reject(err);

    }

  };

});

}]);

改api共有4个方法,分别为request ,requestError ,response ,responseError ,这个四个方法非必选,可根据需要调用,前两个是请求的前置处理,后两个是针对请求的响应的处理。

  • request :接收一个参数,它是 $http 中的标准 config 对象,同时也需要返回一个标准 config ,此时可以添加各类身份验证信息,同时也可在此启动进度条
  • requestError :当有多个 Interceptor 的时候, requestError 会在前一个 Interceptor 抛出错误或者执行 $q.reject() 时执行,接收的参数就对应的错误
  • response :接受一个请求对象参数,可以不处理就直接返回,此时也可以将进度条显示为成功完成,当然,如果后端 API 返回自定义错误时,HTTP 的状态码仍然是 200 得话,便在这里处理自定义错误,也可以对返回数据做一些处理,注意要将进度条置为完成
  • responseError :这个是重头戏,即可以处理标准的 Http 错误,如服务器没有响应时,或者 PHP 之类的 CGI 经常出现的 502 一类,还可以处理 HTTP 状态码不是 200 的各类自定义错误

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...