javascript – 将自定义用户代理与特定的Google Chrome页面/标签相关联

前端之家收集整理的这篇文章主要介绍了javascript – 将自定义用户代理与特定的Google Chrome页面/标签相关联前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在开发Google Chrome扩展程序,我想在标签/页面或弹出窗口(iframe显示为“气泡弹出窗口”)中设置特定用户代理,而不会影响其他页面标签.

可能吗?

解决方法

webRequest API可用于修改User Agent标头.
注意:Developer工具的Network选项卡显示标题.我已经使用 netcat(nc -l 127.0.0.1 -p 6789)验证了标题设置正确.

在下面的示例中,代码在所有选项卡上激活.调整request filter以满足您的要求.添加tabId以限制此过滤器的功能,使用选项卡的tabId(可通过各种API获取,特别是chrome.tabs).

background.js

chrome.webRequest.onBeforeSendHeaders.addListener(
    function(info) {
        // Replace the User-Agent header
        var headers = info.requestHeaders;
        headers.forEach(function(header,i) {
            if (header.name.toLowerCase() == 'user-agent') { 
                header.value = 'Spoofed UA';
            }
        });  
        return {requestHeaders: headers};
    },// Request filter
    {
        // Modify the headers for these pages
        urls: [
            "https://stackoverflow.com/*","http://127.0.0.1:6789/*"
        ],// In the main window and frames
        types: ["main_frame","sub_frame"]
    },["blocking","requestHeaders"]
);

的manifest.json

{
  "name": "WebRequest UA test","version": "1.0","permissions": ["webRequest","webRequestBlocking","http://*/*"],"background": {
    "scripts": ["background.js"]
  },"manifest_version": 2
}

文档

> chrome.webRequest.onbeforeSendHeaders活动
> Request filter

猜你在找的JavaScript相关文章