如何使用chrome-extension收听xhr响应?

Chr*_*ong 3 javascript google-chrome xmlhttprequest google-chrome-extension

为了简化问题,让我这样描述。我想在某些Chrome窗口收到xhr响应时执行一个函数。我不知道此请求的确切含义,因为此请求的编码参数例如:api.xxx.com/rest?random=123

所以我认为我不能使用

chrome.devtools.network.onRequestFinished.addListener(function callback)
Run Code Online (Sandbox Code Playgroud)

要么

chrome.webRequest.onCompleted.addListener(function callback)
Run Code Online (Sandbox Code Playgroud)

两者都需要指定请求详细信息。

gka*_*pak 5

这些事件的侦听器不需要您指定请求详细信息。相反,在被调用时,它们会为您提供这些详细信息。

由于您想听任何XHR请求,因此可以定义特殊的<all_urls>匹配模式(或*://*/*将它们限制为仅http/https请求)。

例如:

chrome.webRequest.onCompleted.addListener(function (details) {
  // Process the XHR response.
  ...
}, {urls: ['<all_urls>']});
Run Code Online (Sandbox Code Playgroud)

不要忘记根据您的要求声明适当的权限。
例如:

// In `manifest.json`:
...
"permissions": {
  ...
  "webRequest",
  "<all_urls>"   // <-- add this to listen for XHR from all pages
]
Run Code Online (Sandbox Code Playgroud)

  • 我不认为 `webRequest` API 可以访问响应正文。您可以访问响应标头和状态代码,仅此而已。 (6认同)
  • 这不会授予对responseBody的访问权限 (3认同)