详解AngularJS用Interceptors来统一处理HTTP请求和响应


Posted in Javascript onJune 08, 2017

Web 开发中,除了数据操作之外,最频繁的就是发起和处理各种 HTTP 请求了,加上 HTTP 请求又是异步的,如果在每个请求中来单独捕获各种常规错误,处理各类自定义错误,那将会有大量的功能类似的代码,或者使用丑陋的方法在每个请求中调用某几个自定义的函数来处理。这两种方法基本都不是靠谱之选。好在 AngularJS 提供了 Interceptors ——拦截战斗机——来对应用内所有的 XHR 请求进行统一处理。

主要功能

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

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

所以,不难理解它可以用于如下几个方面:

  1. 全局处理错误
  2. 统一进行身份验证一类的处理
  3. 对所有发出去的请求进行预处理
  4. 对所有收到的响应进行预处理
  5. 做一些增强用户体验的操作,例如显示一个进度条

基本使用

先来看看最基本的使用:

var app = angular.module('app', []);

// 定义一个 Service ,稍等将会把它作为 Interceptors 的处理函数
app.factory('HttpInterceptor', ['$q', HttpInterceptor]);

function HttpInterceptor($q) {
 return {
  request: function(config){
   return config;
  },
  requestError: function(err){
   return $q.reject(err);
  },
  response: function(res){
   return res;
  },
  responseError: function(err){
   if(-1 === err.status) {
    // 远程服务器无响应
   } else if(500 === err.status) {
    // 处理各类自定义错误
   } else if(501 === err.status) {
    // ...
   }
   return $q.reject(err);
  }
 };
}

// 添加对应的 Interceptors
app.config(['$httpProvider', function($httpProvider){
 $httpProvider.interceptors.push(HttpInterceptor);
}]);

进一步了解

实际的 Interceptor 处理函数中, return 了一个包含四个成员的对象,这四个成员都 不是必须 的,可以按实际情况指定一二,分别如下:

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

上面四个中,前两个是请求的前置处理,后两个是针对请求的响应的处理。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
你真的了解JavaScript吗?
Feb 24 Javascript
javascript实现动态增加删除表格行(兼容IE/FF)
Apr 02 Javascript
javascript十个最常用的自定义函数(中文版)
Sep 07 Javascript
jquery 防止表单重复提交代码
Jan 21 Javascript
jQuery中hover与mouseover和mouseout的区别分析
Dec 24 Javascript
AngularJs $parse、$eval和$observe、$watch详解
Sep 21 Javascript
JavaScript获取URL参数的方法之一
Mar 24 Javascript
基于 flexible 的 Vue 组件:Toast -- 显示框效果
Dec 26 Javascript
Vuex的初探与实战小结
Nov 26 Javascript
jQuery实现放大镜案例
Oct 19 jQuery
JavaScript实现表单验证功能
Dec 09 Javascript
vue使用element-ui按需引入
May 20 Vue.js
微信小程序开发之实现自定义Toast弹框
Jun 08 #Javascript
微信小程序开发之toast等弹框提示使用教程
Jun 08 #Javascript
javascript实现二叉树遍历的代码
Jun 08 #Javascript
微信小程序tabbar不显示解决办法
Jun 08 #Javascript
javascript实现二叉树的代码
Jun 08 #Javascript
微信小程序搜索组件wxSearch实例详解
Jun 08 #Javascript
JS去掉字符串前后空格、阻止表单提交的实现代码
Jun 08 #Javascript
You might like
收集的PHP中与数组相关的函数
2007/03/22 PHP
具有时效性的php加密解密函数代码
2013/06/19 PHP
深入解析php中的foreach问题
2013/06/30 PHP
关于Yii2框架跑脚本时内存泄漏问题的分析与解决
2019/12/01 PHP
JavaScript版代码高亮
2006/06/26 Javascript
js中哈希表的几种用法总结
2014/01/28 Javascript
AngularJS ng-change 指令的详解及简单实例
2016/07/30 Javascript
H5移动端图片压缩上传开发流程
2016/11/09 Javascript
AngularJS使用ng-app自动加载bootstrap框架问题分析
2017/01/04 Javascript
jQuery使用siblings获取某元素所有同辈(兄弟姐妹)元素用法示例
2017/01/30 Javascript
微信小程序开发之选项卡(窗口底部TabBar)页面切换
2017/04/12 Javascript
JS实现div模块的截图并下载功能
2017/10/17 Javascript
深入理解JS的事件绑定、事件流模型
2018/05/13 Javascript
详解vuex之store拆分即多模块状态管理(modules)篇
2018/11/13 Javascript
Layui数据表格跳转到指定页的实现方法
2019/09/05 Javascript
Vue过渡效果之CSS过渡详解(结合transition,animation,animate.css)
2020/02/05 Javascript
JavaScript布尔运算符原理使用解析
2020/05/06 Javascript
swiper4实现移动端导航栏tab滑动切换
2020/10/16 Javascript
jquery实现加载更多"转圈圈"效果(示例代码)
2020/11/09 jQuery
[02:51]DOTA2英雄基础教程 艾欧
2014/01/13 DOTA
[03:02]2014DOTA2西雅图邀请赛 让队员自己告诉你DK NAVI备战情况
2014/07/08 DOTA
Python设计模式编程中Adapter适配器模式的使用实例
2016/03/02 Python
Python 爬虫多线程详解及实例代码
2016/10/08 Python
初探利用Python进行图文识别(OCR)
2019/02/26 Python
django框架实现一次性上传多个文件功能示例【批量上传】
2019/06/19 Python
Python二元赋值实用技巧解析
2019/10/25 Python
详解Windows下PyCharm安装Numpy包及无法安装问题解决方案
2020/06/18 Python
Python xlwings插入Excel图片的实现方法
2021/02/26 Python
移动端rem布局的两种实现方法
2018/01/03 HTML / CSS
一个C/C++编程面试题
2013/11/10 面试题
人事部经理岗位职责
2014/03/07 职场文书
小学亲子活动总结
2014/07/01 职场文书
2014年庆祝国庆65周年演讲稿
2014/09/21 职场文书
开展党的群众路线教育实践活动个人对照检查材料
2014/11/05 职场文书
2014年仓库管理工作总结
2014/12/17 职场文书
深度好文:50条没人告诉你的人生经验,句句精辟
2019/08/22 职场文书