0

我正在开发 chrome-extension 以将 UserAgent 更改为您想要的。我使用 chrome-webrequest API,但我无法从第二次重写它......

我尝试监视请求标头。我发现网络请求从第二个请求开始增加。

我想解决这个问题。

这是我的代码。我认为这个问题的原因是chrome.webRequest.onBeforeSendHeaders.addListener(...)

但是,我不知道。

谁能给我一些建议??

class BrowserConfig {
  apply (userAgent, language) {
  let targetURL = "<all_urls>"
  function rewriteHeader(e) {
    e.requestHeaders.forEach(function(header){
      let headerName = header.name.toLowerCase();
      if (headerName === "user-agent") {
        header.value = userAgent;
      }
    });
    return {requestHeaders: e.requestHeaders};
  }
  
  // the cause of this problem....?
  chrome.webRequest.onBeforeSendHeaders.addListener(
    rewriteHeader,
    {urls: [targetURL]},
    ["blocking", "requestHeaders", "extraHeaders"]
  );
}
import BrowserConfig from 'pass/to/BrowserConfig.js'
const browserConfig = new BrowserConfig()

// browserOptions example...  {userAgent: HeadlessChrome}
chrome.storage.local.get('browserOptions', ({ browserOptions }) => {
    this.browserConfig.apply(browserOptions.userAgent)
})

预期行为

// 1st
set userAgent = 'aaaaa'
=> requestHeader = [{name: 'User-Agent', value: 'aaaaa'}]

// 2nd
set userAgent = 'bbbbb'
=> requestHeader = [{name: 'User-Agent', value: 'bbbbb'}]

实际行为

// 1st
set userAgent = 'aaaaa'
=> requestHeader = [{name: 'User-Agent', value: 'aaaaa'}]

// 2nd
set userAgent = 'bbbbb'
=> // webrequest end up send 2 times.....
requestHeader = [{name: 'User-Agent', value: 'aaaaa'}]
requestHeader = [{name: 'User-Agent', value: 'bbbbb'}]

// 3rd
set userAgent = 'ccccc'
=> 
requestHeader = [{name: 'User-Agent', value: 'aaaaa'}]
requestHeader = [{name: 'User-Agent', value: 'bbbbb'}]
requestHeader = [{name: 'User-Agent', value: 'ccccc'}]
4

1 回答 1

1

我可以看到您已经完成了addListener但看不到removeListener. 如果您不删除侦听器,所有侦听器都会被触发。因此,当您第一次使用“aaaaa”添加它时,它会按预期工作。下一次,有两个动作发生,第一个“aaaaa”监听器,第二个“bbbbb”监听器,以此类推。

查看此页面https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/webRequest/onBeforeSendHeaders并在更新/修改用户代理时删除侦听器。

于 2020-08-13T06:57:47.510 回答