在 Chrome 扩展程序中为 HTTP 请求设置用户代理

Set user agent for HTTP request in Chrome extension

本文关键字:HTTP 请求 设置 用户代理 Chrome 扩展 程序      更新时间:2023-09-26

我正在用纯JavaScript编写一个Chrome扩展程序,并希望将HTTP请求的用户代理更改为给定的URL,因为该URL的所有者已请求使用某种格式的用户代理。

以下代码一直有效,直到添加用户代理修改行,此时 Chrome 检查器控制台会给出错误Refused to set unsafe header "User-Agent"

var xhr = new XMLHttpRequest();
xhr.open("GET", serviceURL, true, username, password);
xhr.setRequestHeader('User-Agent', 'MyExtensionName/0.0.1');
xhr.onreadystatechange = function() {
    // do some stuff
}
xhr.send(null);

为什么无法以这种方式修改用户代理?

您不能在此类请求中设置该标题,浏览器将阻止它 - 以及许多其他标头类型。

但是,在Chrome扩展程序中,您可以使用chrome.webRequest来更改标头。

这将调整用户代理。按照匹配模式指南更改为所需的网址。请记住将 webRequest 和 webRequestBlock 的权限添加到清单中。

chrome.webRequest.onBeforeSendHeaders.addListener(function(details){
    for(var i=0; i < details.requestHeaders.length; ++i){
        if(details.requestHeaders[i].name === "User-Agent"){
            details.requestHeaders[i].value = "Desired User Agent Here";
            break;
        }
    }
    return {requestHeaders: details.requestHeaders};
}, {urls: ["<all_urls>"]}, ["blocking", "requestHeaders"]);