当前位置: 首页 > article >正文

AngularJS XMLHttpRequest

AngularJS XMLHttpRequest (HTTP 请求) 学习笔记在 AngularJS 中$http服务是处理 XMLHttpRequest (XHR) 的核心工具。它封装了原生的XMLHttpRequest对象提供了基于Promise的异步 API并集成了拦截器、转换器和自动的 CSRF 保护。一、核心概念$http服务1. 什么是$http定义AngularJS 内置服务用于与远程服务器进行 HTTP 通信。原理底层封装了原生的XMLHttpRequest或JSONP。返回值返回一个Promise对象基于$q服务支持.then()链式调用。自动处理自动解析 JSON 响应。自动设置Content-Type头。自动处理 CSRF Token如果配置了。2. 基本用法app.controller(MyCtrl,function($scope,$http){// GET 请求$http.get(/api/users).then(function(response){// 成功回调$scope.usersresponse.data;}).catch(function(error){// 错误回调console.error(Error:,error.status,error.statusText);});});二、HTTP 方法详解$http支持所有标准的 HTTP 方法每个方法都返回一个 Promise。1.GET- 获取数据$http.get(/api/users,{params:{page:1,size:10}// 自动转换为查询字符串 ?page1size10}).then(function(response){$scope.usersresponse.data;});2.POST- 提交数据$http.post(/api/users,{name:John,age:25}).then(function(response){$scope.message用户创建成功;});3.PUT- 更新数据$http.put(/api/users/1,{name:Jane,age:26}).then(function(response){$scope.message用户更新成功;});4.DELETE- 删除数据$http.delete(/api/users/1).then(function(response){$scope.message用户删除成功;});5.PATCH- 部分更新$http.patch(/api/users/1,{age:27}).then(function(response){// 处理响应});6.JSONP- 跨域请求// 注意JSONP 需要服务器支持 callback 参数$http.jsonp(/api/users?callbackJSONP_CALLBACK).then(function(response){$scope.usersresponse.data;});三、请求配置对象 (Config Object)所有 HTTP 方法都接受一个可选的配置对象用于自定义请求行为。$http({method:POST,// 请求方法url:/api/users,// 请求 URLheaders:{// 自定义请求头Content-Type:application/json,Authorization:Bearer token123},params:{// GET 请求的查询参数page:1,size:10},data:{// POST/PUT 的请求体name:John,age:25},timeout:5000,// 超时时间毫秒transformRequest:[],// 自定义请求数据转换函数transformResponse:[],// 自定义响应数据转换函数cache:true,// 启用缓存withCredentials:true// 允许发送 Cookie}).then(successCallback,errorCallback);常用配置项详解headers设置自定义 HTTP 头如 Token、Content-Type。params自动附加到 URL 的查询参数GET 请求。data请求体数据POST/PUT/PATCH。timeout请求超时时间超过则自动取消。cachetrue使用$http默认缓存。false禁用缓存。CacheService使用自定义缓存服务。withCredentials跨域请求时携带 Cookie需服务器支持 CORS。四、响应对象结构$http的 Promise 成功回调接收一个响应对象包含以下属性$http.get(/api/users).then(function(response){// response.data: 响应体已自动解析 JSON// response.status: HTTP 状态码 (200, 404, 500...)// response.headers: 响应头获取函数// response.config: 原始请求配置对象// response.statusText: 状态文本 (OK, Not Found)console.log(response.data);console.log(response.status);});错误响应$http.get(/api/users).catch(function(response){// response.status: 错误状态码 (404, 500...)// response.data: 错误信息// response.statusText: 错误文本// response.config: 原始请求配置});五、快捷方法 vs 通用方法方法语法适用场景快捷方法$http.get(),$http.post()简单请求代码简洁通用方法$http({ method: ..., ... })复杂配置自定义头、超时、转换器等示例对比// 快捷方法$http.get(/api/users,{params:{id:1}});// 通用方法功能相同$http({method:GET,url:/api/users,params:{id:1}});六、拦截器 (Interceptors)拦截器是$http的强大功能允许在请求发送前或响应返回后全局拦截和修改数据。1. 定义拦截器app.factory(HttpInterceptor,function($q,$injector){return{// 请求拦截器request:function(config){// 添加 Tokenconfig.headers[Authorization]Bearer localStorage.getItem(token);returnconfig;},// 请求错误拦截器requestError:function(rejection){console.error(请求错误:,rejection);return$q.reject(rejection);},// 响应拦截器response:function(response){// 处理成功响应if(response.status200){// 可以修改响应数据}returnresponse;},// 响应错误拦截器responseError:function(rejection){// 统一处理错误如 401 跳转登录if(rejection.status401){// 跳转到登录页window.location.href/login;}return$q.reject(rejection);}};});2. 注册拦截器app.config(function($httpProvider){$httpProvider.interceptors.push(HttpInterceptor);// 或者推入函数$httpProvider.interceptors.push(function($q){return{request:function(config){...}};});});3. 典型应用场景统一添加 Token在request中注入 JWT。全局错误处理在responseError中处理 401/403/500。请求加载动画在request中显示 Loadingresponse中隐藏。数据转换统一格式化请求/响应数据。七、请求取消 (Cancelling Requests)AngularJS 支持取消未完成的 HTTP 请求防止内存泄漏和无效请求。1. 使用timeout配置varcanceler$q.defer();$http.get(/api/users,{timeout:canceler.promise}).then(function(response){// 处理响应});// 取消请求canceler.resolve();2. 在控制器销毁时取消app.controller(UserCtrl,function($scope,$http,$q){varcanceler$q.defer();$http.get(/api/users,{timeout:canceler.promise}).then(function(response){$scope.usersresponse.data;});// 控制器销毁时取消请求$scope.$on($destroy,function(){canceler.resolve();});});八、CSRF 保护AngularJS 自动处理 CSRF跨站请求伪造保护。1. 配置默认从 Cookie 读取XSRF-TOKEN。自动在请求头中添加X-XSRF-TOKEN。配置项$httpProvider.defaults.xsrfCookieName和$httpProvider.defaults.xsrfHeaderName。app.config(function($httpProvider){$httpProvider.defaults.xsrfCookieNameXSRF-TOKEN;$httpProvider.defaults.xsrfHeaderNameX-XSRF-TOKEN;});2. 后端配合后端需设置XSRF-TOKENCookie。后端需验证请求头中的X-XSRF-TOKEN。九、最佳实践1. 封装 API 服务不要直接在控制器中写$http应封装到 Service 中。// services/api.jsapp.factory(UserService,function($http){return{getAll:function(){return$http.get(/api/users);},getById:function(id){return$http.get(/api/users/id);},create:function(user){return$http.post(/api/users,user);}};});// 控制器中使用app.controller(UserCtrl,function($scope,UserService){UserService.getAll().then(function(res){$scope.usersres.data;});});2. 统一错误处理使用拦截器统一处理错误避免在每个控制器中重复写catch。3. 避免内存泄漏在$destroy事件中取消未完成的请求。避免在循环中发起大量请求使用防抖或节流。4. 使用 Promise 链// ✅ 好链式调用UserService.getAll().then(function(res){$scope.usersres.data;returnUserService.getStats();}).then(function(stats){$scope.statsstats.data;}).catch(function(error){console.error(Error:,error);});5. 处理大文件上传使用FormData和transformRequest: angular.identity。varformDatanewFormData();formData.append(file,fileInput.files[0]);$http.post(/api/upload,formData,{headers:{Content-Type:undefined},transformRequest:angular.identity});十、常见问题与解决方案问题原因解决方案跨域错误 (CORS)服务器未配置 CORS 头服务器添加Access-Control-Allow-OriginCSRF 失败Cookie 或 Header 名称不匹配检查$httpProvider配置和后端设置数据未更新异步回调中未触发$apply使用 Promise 或$timeout请求被取消组件销毁时未清理在$destroy中调用canceler.resolve()JSON 解析失败响应不是标准 JSON检查transformResponse或服务器返回格式重复请求快速点击导致多次提交使用防抖或禁用按钮十一、总结AngularJS$http服务的核心要点Promise 基础所有请求返回 Promise支持.then()和.catch()。配置灵活支持自定义头、参数、超时、缓存等。拦截器强大全局处理请求/响应统一添加 Token、处理错误。自动处理JSON 解析、CSRF 保护、错误状态码。封装原则将$http封装到 Service控制器只负责业务逻辑。资源清理在组件销毁时取消未完成的请求防止内存泄漏。通过合理使用$http和拦截器可以构建出健壮、可维护的异步数据交互层。

相关文章:

AngularJS XMLHttpRequest

AngularJS XMLHttpRequest (HTTP 请求) 学习笔记 在 AngularJS 中,$http 服务是处理 XMLHttpRequest (XHR) 的核心工具。它封装了原生的 XMLHttpRequest 对象,提供了基于 Promise 的异步 API,并集成了拦截器、转换器和自动的 CSRF 保护。 一…...

AngularJS 服务(Service)

AngularJS 服务 (Service) 学习笔记 服务(Service)是 AngularJS 中用于封装业务逻辑、数据访问和通用功能的组件。它是实现关注点分离(Separation of Concerns)和依赖注入(Dependency Injection)的核心机制…...

从异步FIFO到MCP:用VC Spyglass CDC验证多bit数据跨时钟传输的完整方案

从异步FIFO到MCP:多bit数据跨时钟域传输的黄金法则 在复杂SoC设计中,数据总线跨越不同时钟域的场景比比皆是。无论是处理器与外围设备的交互,还是芯片内部不同功能模块间的数据交换,时钟域交叉(CDC)问题始终…...

告别卡顿!用FFmpeg的GPU硬解码加速你的视频处理流程(NVIDIA CUDA实测)

告别卡顿!用FFmpeg的GPU硬解码加速你的视频处理流程(NVIDIA CUDA实测) 视频处理工作流中,最令人头疼的莫过于漫长的转码等待时间。当你的4K素材在时间线上预览卡顿,或是批量转码任务让CPU占用率飙升到100%时&#xff0…...

从RCRB到BAR:手把手教你理解PCIe设备的地址空间与配置(附实战配置流程)

深入解析PCIe设备地址空间:从RCRB到BAR的实战指南 在嵌入式系统与高性能计算领域,PCIe总线作为连接CPU与外围设备的核心通道,其地址空间配置的准确性直接决定了系统能否稳定运行。本文将带您深入PCIe设备的硬件视角,揭示RCRB与BAR…...

手把手教你用STM32CubeMX配置SPI2,5分钟搞定RC522门禁卡读写

STM32CubeMX实战:5分钟完成RC522门禁卡系统开发 在物联网和智能硬件快速发展的今天,门禁系统作为安防领域的重要组成部分,正经历着从传统向智能化的转变。而RFID技术凭借其非接触式识别的特性,成为门禁系统的核心技术之一。本文将…...

别急着换Ubuntu!在Fedora上搞定U-Boot交叉编译的‘multiple definition of yylloc‘报错

在Fedora上根治U-Boot交叉编译的yylloc多重定义错误 当你在Fedora 35或更高版本上交叉编译较旧版本的U-Boot时,可能会遇到一个令人头疼的错误:"multiple definition of yylloc"。这个错误通常出现在编译dtc(设备树编译器&#xff0…...

DS4Windows终极指南:3步让PlayStation手柄在Windows上完美运行

DS4Windows终极指南:3步让PlayStation手柄在Windows上完美运行 【免费下载链接】DS4Windows Like those other ds4tools, but sexier 项目地址: https://gitcode.com/gh_mirrors/ds/DS4Windows 还在为PC游戏无法识别你的PlayStation手柄而烦恼吗?…...

XXMI启动器:六款主流二次元游戏模组管理的统一解决方案

XXMI启动器:六款主流二次元游戏模组管理的统一解决方案 【免费下载链接】XXMI-Launcher Modding platform for GI, HSR, WW and ZZZ 项目地址: https://gitcode.com/gh_mirrors/xx/XXMI-Launcher 在当今游戏模组管理领域,XXMI启动器作为一款创新的…...

解锁音乐自由:qmcdump如何让QQ音乐加密文件重获新生

解锁音乐自由:qmcdump如何让QQ音乐加密文件重获新生 【免费下载链接】qmcdump 一个简单的QQ音乐解码(qmcflac/qmc0/qmc3 转 flac/mp3),仅为个人学习参考用。 项目地址: https://gitcode.com/gh_mirrors/qm/qmcdump 你是否曾…...

别再只调饱和度了!从人眼视觉到sRGB:深入理解CCM在手机拍照里的‘隐形’作用

手机摄影的色彩密码:揭开CCM如何重塑你的每一张照片 清晨的阳光洒在公园长椅上,你用不同品牌的手机拍摄同一片郁金香花海——华为的鲜艳夺目、iPhone的真实自然、小米的浓郁厚重。这些风格差异的背后,藏着一个被99%用户忽略的关键技术&#x…...

8大网盘直链解析神器:告别限速,体验全速下载的终极方案

8大网盘直链解析神器:告别限速,体验全速下载的终极方案 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动…...

169.254.x.x:当你的HP打印机决定‘单飞’时,它在想什么?(聊聊APIPA协议与局域网那些事儿)

169.254.x.x:当你的HP打印机决定‘单飞’时,它在想什么? 想象一下这样的场景:你正准备打印一份重要文件,却发现打印机状态显示"脱机"。检查网络配置时,一个奇怪的IP地址映入眼帘——169.254.23.4…...

用MobileNet搞定垃圾分类:基于TensorFlow2.3,从数据清洗到GUI部署的完整实战

用MobileNet实现高精度垃圾分类:从数据预处理到PyQt5部署的全流程解析 垃圾分类作为计算机视觉在环保领域的典型应用,对模型轻量化和工程化部署提出了独特挑战。本文将手把手带您实现一个准确率达82%的垃圾分类系统,重点解决实际开发中的三个…...

ESP32-C3 SPI避坑指南:从模式选择到时钟配置,新手必看的5个常见错误

ESP32-C3 SPI避坑实战:5个高频错误与精准调试策略 当你在深夜调试ESP32-C3的SPI通信时,示波器上那些不规则的波形是否曾让你抓狂?作为物联网开发中最常用的通信协议之一,SPI以其高速、全双工的特性深受开发者青睐,但ES…...

IIR滤波器计算优化:双路径全通结构解析

1. IIR滤波器计算优化:双路径全通滤波器方法解析 在数字信号处理领域,IIR(无限脉冲响应)滤波器因其高效的频率选择特性而被广泛应用于音频处理、通信系统和生物医学信号分析等多个场景。然而,传统IIR滤波器实现面临一个…...

从理论到芯片:深入浅出聊聊STM32的DSP复数运算到底在算什么?

从理论到芯片:深入浅出聊聊STM32的DSP复数运算到底在算什么? 当我们谈论复数运算时,脑海中浮现的可能是高数课本里那些抽象的公式和符号。但在嵌入式开发的世界里,复数运算却实实在在地影响着通信系统的误码率、电机控制的精度&am…...

告别虚拟机!用树莓派4打造你的专属移动SLAM小车:硬件选配、系统烧录到ORB-SLAM3运行全记录

用树莓派4构建移动SLAM小车:从硬件组装到ORB-SLAM3实战指南 当机器人爱好者第一次尝试将SLAM算法部署到实体设备时,往往会面临硬件兼容性、系统优化和实时性三大挑战。本文将带你用树莓派4打造一个可移动的SLAM演示平台,不仅解决ORB-SLAM3在A…...

告别LabelImg!用Roboflow一站式搞定YOLOv5/v8自定义数据集(附完整代码)

告别LabelImg!用Roboflow一站式搞定YOLOv5/v8自定义数据集 在计算机视觉项目的开发流程中,数据标注环节往往是最耗时且容易出错的阶段。传统方法需要经历本地安装标注工具、手动标注、格式转换、数据增强等多个独立步骤,整个过程就像在玩一个…...

告别‘白屏’:ST7701s驱动移植避坑指南(基于常见MCU平台)

ST7701s驱动移植实战:从白屏到完美显示的深度解析 当一块480480分辨率的ST7701s屏幕在你的开发板上持续显示白屏时,那种挫败感每个嵌入式工程师都深有体会。供应商提供的初始化代码看似完美,但移植到STM32、ESP32或全志平台时却屡屡碰壁。本文…...

【ClickHouse实战】巧用IFNULL、COALESCE与NULLIF:构建健壮查询的默认值策略

1. 空值处理的必要性:为什么我们需要默认值策略? 在数据分析领域,空值(NULL)就像数据海洋中的暗礁,稍不注意就会导致查询结果偏离预期。特别是在ClickHouse这类高性能分析型数据库中,空值处理不…...

2026届毕业生推荐的十大降AI率工具实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 若要降低AIGC(AI生成内容)的检测概率,得从文本特征着手。…...

保姆级教程:用WoLF PSORT、YLoc和DeepLoc 2.0搞定蛋白质亚细胞定位预测(附结果解读)

蛋白质亚细胞定位预测实战指南:WoLF PSORT/YLoc/DeepLoc 2.0全流程解析 当你在实验室首次拿到Nanog蛋白序列时,是否曾对着满屏的预测结果感到困惑?三个工具给出了相似但不完全相同的定位建议,该相信哪一个?这份指南将…...

Blender 3MF插件:快速掌握3D打印工作流的核心工具

Blender 3MF插件:快速掌握3D打印工作流的核心工具 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 在3D打印的世界里,你是否曾遇到过这样的困扰&am…...

Win11自动隐藏任务栏下,QQ/微信消息弹窗烦人?实测这3种设置组合能根治

Win11自动隐藏任务栏下根治QQ/微信消息弹窗的3种终极方案 每次全屏写文档时,右下角突然弹出的黄色闪烁图标总让人血压飙升——这可能是Win11自动隐藏任务栏用户最常遭遇的现代办公酷刑。明明选择了隐藏任务栏追求极简,聊天软件却固执地破坏这份宁静。经过…...

从VGG到RepVGG:一个‘重参数化’技巧,如何让经典CNN在训练和推理中‘两头吃香’?

从VGG到RepVGG:重参数化如何重塑经典CNN的现代价值 在计算机视觉领域,卷积神经网络(CNN)的架构演进就像一场永不停歇的接力赛。当2014年VGGNet以其优雅的对称结构和重复堆叠的33卷积层惊艳学界时,没人想到这个"古典美学"代表会在七…...

【Docker 27边缘容器部署终极指南】:20年运维专家亲授轻量化落地的7大避坑法则

第一章:Docker 27边缘容器轻量化部署全景认知 Docker 27(代号“EdgeLight”)是专为边缘计算场景深度优化的轻量级容器运行时,其核心设计摒弃了传统守护进程模型,转而采用无守护、按需加载的模块化架构。该版本将镜像拉…...

从.NET 8到.NET 10预览版:C# 14 AOT编译Dify客户端的3次架构跃迁,第3次将彻底淘汰MSI安装包

第一章:C# 14 原生 AOT 部署 Dify 客户端 2026 最新趋势C# 14 正式引入对原生 AOT(Ahead-of-Time)编译的深度集成支持,结合 .NET 9 的跨平台运行时优化,为构建轻量、安全、启动极速的 Dify 客户端提供了全新范式。Dify…...

Phi-3.5-mini-instruct部署教程:vLLM服务容器化+Prometheus指标暴露配置

Phi-3.5-mini-instruct部署教程:vLLM服务容器化Prometheus指标暴露配置 1. 模型简介 Phi-3.5-mini-instruct 是一个轻量级的开放模型,属于Phi-3模型家族。它基于高质量的数据集构建,特别关注推理密集型任务。该模型支持128K令牌的上下文长度…...

Ai2Psd终极指南:彻底解决Illustrator到Photoshop无损转换难题

Ai2Psd终极指南:彻底解决Illustrator到Photoshop无损转换难题 【免费下载链接】ai-to-psd A script for prepare export of vector objects from Adobe Illustrator to Photoshop 项目地址: https://gitcode.com/gh_mirrors/ai/ai-to-psd 你是否曾为Illustra…...