electron中如何拦截所有的http请求结果?并对结果进行修改

发布于 2022-09-12 13:23:46 字数 97 浏览 22 评论 0

electron中如何拦截所有的http请求结果?并对结果进行修改.
翻遍了electron文档, 只有request, 没有对Response做处理的, 求教这个怎么解决?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

攒一口袋星星 2022-09-19 13:23:46

Electron WebRequest API

const { session } = require('electron')

// 修改存取下列 URL 時使用的 User Agent。
const filter = {
  urls: ['https://*.github.com/*', '*://electron.github.io']
}

session.defaultSession.webRequest.onBeforeSendHeaders(filter, (details, callback) => {
  details.requestHeaders['User-Agent'] = 'MyAgent'
  callback({ requestHeaders: details.requestHeaders })
})
昇り龍 2022-09-19 13:23:46

可以用protocol.interceptHttpProtocol拦截请求,修改并返回一个新请求,要注意在callback的时候要用新session,否则新的请求又会被拦截,无限循环

漫雪独思 2022-09-19 13:23:46

https://www.electronjs.org/zh...

protocol.registerBufferProtocol(scheme, handler) 可以直接写返回值

姐不稀罕 2022-09-19 13:23:46

可以使用debugger API把response响应内容打印出来,但是不可以修改。

mainWindow.webContents.debugger.on('detach', (event, reason) => {
  console.log('Debugger detached due to: ', reason);
});

mainWindow.webContents.debugger.on('message', (event, method, params) => {
  if (method === 'Network.responseReceived') {
    console.log(params.response.url);
    mainWindow.webContents.debugger.sendCommand('Network.getResponseBody', { requestId: params.requestId }).then(function(response) {
      console.log(response);
    });
  }
})
  
mainWindow.webContents.debugger.sendCommand('Network.enable');
万水千山粽是情ミ 2022-09-19 13:23:46

哥们。咋样。这样的功能后来怎么处理的

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文