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

发布时间 - 2026-01-11 01:47:57    点击率:

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 的各类自定义错误

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

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


# AngularJS  # Interceptors  # http请求和响应  # 对angular 监控数据模型变化的事件方法$watch详解  # 关于angular js_$watch监控属性和对象详解  # 分享Angular http interceptors 拦截器使用(推荐)  # angular中的http拦截器Interceptors的实现  # Angular通过 HTTP Interceptor 实现 HTTP 请求超时监控的例子  # 自定义  # 进度条  # 也可  # 身份验证  # 几个  # 在这里  # 会有  # 还可以  # 又是  # 多个  # 将会  # 在此  # 在每个  # 把它  # 它是  # 它可以  # 实际情况  # 要将  # 仍然是  # 在前 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 微信h5制作网站有哪些,免费微信H5页面制作工具?  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  如何在阿里云完成域名注册与建站?  如何确认建站备案号应放置的具体位置?  如何在香港服务器上快速搭建免备案网站?  高性价比服务器租赁——企业级配置与24小时运维服务  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  Bootstrap整体框架之JavaScript插件架构  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  Laravel如何处理表单验证?(Requests代码示例)  Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  详解CentOS6.5 安装 MySQL5.1.71的方法  Android中AutoCompleteTextView自动提示  如何在阿里云香港服务器快速搭建网站?  如何快速打造个性化非模板自助建站?  如何用景安虚拟主机手机版绑定域名建站?  详解Oracle修改字段类型方法总结  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  nginx修改上传文件大小限制的方法  如何快速完成中国万网建站详细流程?  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  详解Android图表 MPAndroidChart折线图  晋江文学城电脑版官网 晋江文学城网页版直接进入  php json中文编码为null的解决办法  如何在阿里云虚拟主机上快速搭建个人网站?  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  北京网站制作公司哪家好一点,北京租房网站有哪些?  如何用IIS7快速搭建并优化网站站点?  高防服务器租用如何选择配置与防御等级?  Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  Laravel如何自定义分页视图?(Pagination示例)  linux写shell需要注意的问题(必看)  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  🚀拖拽式CMS建站能否实现高效与个性化并存?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  郑州企业网站制作公司,郑州招聘网站有哪些?  开心动漫网站制作软件下载,十分开心动画为何停播?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  Laravel如何使用Telescope进行调试?(安装和使用教程)  canvas 画布在主流浏览器中的尺寸限制详细介绍  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  微信公众帐号开发教程之图文消息全攻略