全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

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 请求超时监控的例子  # 自定义  # 进度条  # 也可  # 身份验证  # 几个  # 在这里  # 会有  # 还可以  # 又是  # 多个  # 将会  # 在此  # 在每个  # 把它  # 它是  # 它可以  # 实际情况  # 要将  # 仍然是  # 在前 


相关文章: 矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  如何在橙子建站上传落地页?操作指南详解  如何快速搭建个人网站并优化SEO?  教学网站制作软件,学习*后期制作的网站有哪些?  制作销售网站教学视频,销售网站有哪些?  湖北网站制作公司有哪些,湖北清能集团官网?  企业微网站怎么做,公司网站和公众号有什么区别?  制作门户网站的参考文献在哪,小说网站怎么建立?  建站之星2.7模板:企业网站建设与h5定制设计专题  Android滚轮选择时间控件使用详解  阿里云网站制作公司,阿里云快速搭建网站好用吗?  制作公司内部网站有哪些,内网如何建网站?  建站主机选购指南:核心配置与性价比推荐解析  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  家具网站制作软件,家具厂怎么跑业务?  如何在万网主机上快速搭建网站?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  如何基于云服务器快速搭建网站及云盘系统?  ,制作一个手机app网站要多少钱?  平台云上自助建站如何快速打造专业网站?  家庭建站与云服务器建站,如何选择更优?  一键网站制作软件,义乌购一件代发流程?  建站之星CMS五站合一模板配置与SEO优化指南  公司门户网站制作流程,华为官网怎么做?  建站之星logo尺寸如何设置最合适?  如何在云服务器上快速搭建个人网站?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  PHP正则匹配日期和时间(时间戳转换)的实例代码  如何快速打造个性化非模板自助建站?  上海网站制作开发公司,上海买房比较好的网站有哪些?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  详解jQuery停止动画——stop()方法的使用  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  建站之星安装后界面空白如何解决?  如何选择CMS系统实现快速建站与SEO优化?  如何在VPS电脑上快速搭建网站?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  Android自定义控件实现温度旋转按钮效果  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  岳西云建站教程与模板下载_一站式快速建站系统操作指南  建站之星代理费用多少?最新价格详情介绍  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  平台云上自主建站:模板化设计与智能工具打造高效网站  营销式网站制作方案,销售哪个网站招聘效果最好?  如何在阿里云完成域名注册与建站?  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  如何快速生成可下载的建站源码工具?  如何在建站之星绑定自定义域名? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。