Intercept fetch() API requests and responses in JavaScript(在 JavaScript 中拦截 fetch() API 请求和响应)
问题描述
我想在 JavaScript 中拦截 fetch API 请求和响应.
I want to intercept fetch API requests and responses in JavaScript.
例如,在发送请求之前我要截取请求的 URL.我也想在响应到达后拦截它.
For example, before sending the request I want to intercept the request URL. I'd like to intercept the response once it arrives as well.
以下代码用于拦截所有XMLHTTPRequest的响应.
The below code is for intercepting responses of all XMLHTTPRequests.
(function(open) {
XMLHttpRequest.prototype.open = function(XMLHttpRequest) {
var self = this;
this.addEventListener("readystatechange", function() {
if (this.responseText.length > 0 &&
this.readyState == 4 &&
this.responseURL.indexOf('www.google.com') >= 0) {
Object.defineProperty(self, 'response', {
get: function() { return bValue; },
set: function(newValue) { bValue = newValue; },
enumerable: true,
configurable: true
});
self.response = 'updated value' // Intercepted Value
}
}, false);
open.apply(this, arguments);
};
})(XMLHttpRequest.prototype.open);
我想为 fetch() API 实现相同的功能.我该怎么做?
I want to implement the same feature for fetch() API. How can I do this?
推荐答案
为了拦截获取请求和参数,我们可以采用下面提到的方式.它解决了我的问题.
For intercepting the fetch request and parameter we can go for below mentioned way. its resolved my issue.
const constantMock = window.fetch;
window.fetch = function() {
// Get the parameter in arguments
// Intercept the parameter here
return constantMock.apply(this, arguments)
}
这篇关于在 JavaScript 中拦截 fetch() API 请求和响应的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 JavaScript 中拦截 fetch() API 请求和响应
- 400或500级别的HTTP响应 2022-01-01
- Fetch API 如何获取响应体? 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- addEventListener 在 IE 11 中不起作用 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 失败的 Canvas 360 jquery 插件 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
