首页 > 编程语言 >ajax 源码分析

ajax 源码分析

时间:2023-08-04 10:35:59浏览次数:37  
标签:分析 function return attr hook xhr ajax 源码 let

/**
  源码来源:https://github.com/wendux/Ajax-hook * XHR属性方法: * Type Function: [abort,getAllResponseHeaders,getResponseHeader,open,overrideMimeType,send,setRequestHeader] * type object: [onreadystatechange,upload,responseXML,onprogress,onabort,onloadstart,onload,onloadend,onerror,ontimeout] * type number: [readyState,timeout,UNSENT,OPENED,HEADERS_RECEIVED,LOADING,DONE] * type string: [statusText,responseType,response,responseText] * */ const ORIGINXHR = '__origin__'; export function hook(proxy: any, win?: typeof globalThis) { win = win || window; // 1. 缓存原始的 XMLHttpRequest 对象 let originXhr = win.XMLHttpRequest // @ts-ignore win.XMLHttpRequest = function () { let xhr: any = new originXhr(); for (let attr in xhr) { // @ts-ignore let type = typeof xhr[attr]; // 3. 处理方法:函数类型的注入hooks,重写方法, if (type === "function") { // console.log("attr==type: function=>", type, attr) this[attr] = useHookFunction(attr); } // 4. 处理属性:非函数类型的添加get set, 忽略保存到原始对象。 this.__origin__.toString() == "[object XMLHttpRequest]" // this 指向新的XHR对象 else if (attr !== ORIGINXHR) { // console.log("attr==type: !function=>", type, attr) Object.defineProperty(this, attr, { get: getterFactory(attr), set: setterFactory(attr), enumerable: true // 确保能被for in 循环 }) } } this[ORIGINXHR] = xhr; // console.log(this, "hook XMLHttpRequest") } function useHookFunction(fun: string) { return function () { let args = [].slice.call(arguments); if (proxy[fun]) { let ret = proxy[fun].call(this, args, this[ORIGINXHR]) if (ret) return ret; } return this[ORIGINXHR][fun].apply(this[ORIGINXHR], args); } } function getterFactory(attr: any) { return function () { let v = this.hasOwnProperty(attr + "_") ? this[attr + "_"] : this[ORIGINXHR][attr]; return v; // let attrGetterHook = (proxy[attr] || {})["getter"]; // return attrGetterHook && attrGetterHook(v, this) || v; } } function setterFactory(attr: string) { console.log("all == attr", attr) return function (v: any) { let xhr = this[ORIGINXHR]; // 原始 XHR let that = this; // 新 XHR let hook = proxy[attr]; // 传入的 hook func // 1. 处理的事件: onl oadend,onerror,ontimeout if (attr.startsWith('on')) { console.log("on == attr", attr) that[attr + "_"] = v; console.log("setterFactory", v, proxy[attr]) xhr[attr] = function (e: any) { e = configEvent(e, that) let ret = proxy[attr] && proxy[attr].call(that, xhr, e) // 1. 原始XHR上执行传入的hook事件(方法) console.log("ret", ret) ret || v.call(that, e); // 2.新的XHR上执行外部定义的事件回调 } } // 2. 处理其他属性 else { // 普通属性拦截器写法 // hook( // //需要拦截的属性名 // timeout: { // //拦截写操作 // setter: function (v, xhr) { // //超时最短为1s,返回值为最终值。 // return Math.max(v, 1000); // } // } // ) // let attrSetterHook = (hook || {})["setter"]; // 源码这个写法有问题,修改为如下: let attrSetterHook = hook["setter"] || null; console.log("un event:", attr, attrSetterHook) v = attrSetterHook && attrSetterHook(v, that) || v // 替换普通属性为拦截器的值 this[attr + "_"] = v; // 新的xhr对象上复制属性 try { xhr[attr] = v; // 原始xhr对象赋值属性 } catch (e) { } } } } function unHook() { win!.XMLHttpRequest = originXhr; // @ts-ignore originXhr = undefined; } return { originXhr, unHook } } export function configEvent(event:Event, xhrProxy: any) { let e: any = {}; for (let attr in event) { // @ts-ignore e[attr] = event[attr]; } e.target = e.currentTarget = xhrProxy return e; }

 

标签:分析,function,return,attr,hook,xhr,ajax,源码,let
From: https://www.cnblogs.com/monkey-K/p/17605221.html

相关文章

  • 高效构建 vivo 企业级网络流量分析系统
    作者:vivo互联网服务器团队-MingYujia随着网络规模的快速发展,网络状况的良好与否已经直接关系到了企业的日常收益,故障中的每一秒都会导致大量的用户流失与经济亏损。因此,如何快速发现网络问题与定位异常流量已经成为大型企业内必须优先解决的问题,诸多网络流量分析技术也同时......
  • RTSP流媒体服务器LntonNVR(源码版)视频监控平台通过ODM工具手动输入onvif地址添加通道的
    LntonNVR是一种轻量级的视频监控平台,具有强大的拓展性和高兼容度。它可以支持通过RTSP/ONVIF协议接入前端设备,包括摄像头等。在接入前端设备时,LntonNVR提供了自带的ONVIF探测功能,可以方便地将摄像头设备接入平台。一旦接入成功,您就可以通过LntonNVR实现对摄像头的云台控制,包括转动......
  • Oracle表碎片分析
    在Oracle运维的过程中,会经常遇到说表碎片严重的问题。表碎片严重会导致出现数据库的性能问题,在sql访问数据的时候需要消耗更多的资源,因此常常出现在数据库的优化中。想要获取表碎片的情况,计算方式和处理方式很重要。1.计算表的碎片情况查看某个用户下表的碎片情况,查询信息的准......
  • Python 优化第一步: 性能分析实践 使用cporfile+gprof2dot可视化
    拿来主义:python-mcProfile-oprofile.pstatsto_profile.pygprof2dot-fpstatsprofile.pstats|dot-Tpng-oclick.png然后顺着浅色线条优化就OK了。 windows下:google下graphviz-2.38.msi,然后安装。dot命令需要。gitclone https://github.com/jrfonseca/gprof2dot.git......
  • 基于区块链技术结合联邦学习技术的安全医疗5.0系统 论文分析
    名词解释:IOMT(InternetofMedicalThings):医疗物联网,是将IOT技术应用到医疗保健领域的产物。其重点是连接医疗设备与系统,实现医疗信息和数据的可连接和交换。ML(MachineLearning):机器学习-典型的机器学习任务包括分类、回归、聚类等。常用算法有线性回归、决策树、支持......
  • Woreflint恶意软件c2分析
    WhatisTrojan:Win32/Woreflint.A!clinfection?InthisshortarticleyouwillcertainlydiscoverconcerningthedefinitionofTrojan:Win32/Woreflint.A!clandalsoitsnegativeeffectonyourcomputersystem.Suchransomwareareaformofmalwarethatiscl......
  • Backdoor:Win32/Noancooe 使用IDA进行恶意软件分析
    Backdoor:Win32/Noancooe先看下微软官方怎么说这个恶意软件:DetectedbyMicrosoftDefenderAntivirusAliases:Trojan-Ransom.Win32.Foreign.muyq(Kaspersky)SummaryWindowsDefenderdetectsandremovesthisthreat.Thisthreatcangiveamalicioushackerunauthorize......
  • 数据分析的提升,通过领羊QuickBI数据功能可以简化
    随着大数据时代的到来,越来越多的企业开始意识到数据分析的重要性。他们利用大数据分析来研究市场变化趋势,以调整并优化企业的发展策略。同时,根据市场数据的反馈,企业能够实时评估自己经营决策的效果,从而支持持续发展。在这种背景下,国内自主开发的数据处理工具,例如瓴羊QuickBI,引起了......
  • x86_64 ubuntu22.04环境下编译版本python3.13.0 alpha 0源码——python3.13.0 alpha 0
      python3.13.0alpha0版本源码编译: 环境——x86_64ubuntu22.04系统: 1.源码下载:gitclonehttps://github.com/python/cpython 2.修改apt源地址:编辑文件:sudovim/etc/apt/sources.list添加内容:deb-srchttp://archive.ubuntu.com/ubuntu/jammymain......
  • 【专题】2022年中国母婴用品行业分析报告PDF合集分享(附原数据表)
    报告链接:http://tecdat.cn/?p=31424人口出生红利消失,以及后疫情时代的冲击,但消费升级将负面因素拉平,母婴消费市场总量持续稳步上升。"精致妈妈"的营销价值日益凸显。阅读原文,获取专题报告合集全文,解锁文末56份母婴行业相关报告。当母婴人群成为众多母婴及家庭消费品的重要入口群......