时间:2021-05-25
Web 开发中,除了数据操作之外,最频繁的就是发起和处理各种 HTTP 请求了,加上 HTTP 请求又是异步的,如果在每个请求中来单独捕获各种常规错误,处理各类自定义错误,那将会有大量的功能类似的代码,或者使用丑陋的方法在每个请求中调用某几个自定义的函数来处理。这两种方法基本都不是靠谱之选。好在 AngularJS 提供了 Interceptors ——拦截战斗机——来对应用内所有的 XHR 请求进行统一处理。
主要功能
Interceptors 有两个处理时机,分别是:
所以,不难理解它可以用于如下几个方面:
基本使用
先来看看最基本的使用:
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); } };}// 添加对应的 Interceptorsapp.config(['$httpProvider', function($httpProvider){ $httpProvider.interceptors.push(HttpInterceptor);}]);进一步了解
实际的 Interceptor 处理函数中, return 了一个包含四个成员的对象,这四个成员都 不是必须 的,可以按实际情况指定一二,分别如下:
上面四个中,前两个是请求的前置处理,后两个是针对请求的响应的处理。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在SpringBoot项目中,异常统一处理,可以使用Spring中@ControllerAdvice来统一处理,也可以自己来定义异常处理方案。SpringBoo
使用springmvc提供restful风格的接口,实现前后端分离,后端只提供数据接口,而不做页面渲染。因此可对接口做统一处理:请求参数校验响应数据格式全局异常
vue官方推荐使用axios发送请求首先上需求1.需要封装全局调用2.返回一个promise对象3.错误全局统一处理4.除了登录界面token带入头部5.登录时
详解http请求中的Content-Typehttp头部字段Content-Type约定请求和响应的HTTPbody内容编码类型,客户端和服务端根据http头部
小程序miniso的一个发布内容截图功能,话不多,先上代码wxml文件:1:13:4这里是对多张图片进行统一处理,用户选了哪种截图比例,所有图片用统一规格裁剪。