写一个chrome插件,统一修改所有http请求的header头,包括ajax请求

2024-06-22 03:44

本文主要是介绍写一个chrome插件,统一修改所有http请求的header头,包括ajax请求,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要创建一个可以灵活修改HTTP请求头的Chrome扩展,包括一个用户界面来动态设置头部名称和值,可以按照以下步骤进行。我们会用到 chrome.storage API 来保存用户的设置,并在后台脚本中使用这些设置来修改请求头。

文件结构

my_chrome_extension/
│
├── icons/
│   ├── icon16.png
│   ├── icon48.png
│   └── icon128.png
│
├── background.js
├── manifest.json
├── options.html
├── options.js
├── popup.html
├── popup.js
├── popup.css

manifest.json

{"manifest_version": 2,"name": "Flexible HTTP Headers Modifier","version": "1.0","description": "A Chrome extension to modify HTTP headers with user-defined values","permissions": ["storage","webRequest","webRequestBlocking","<all_urls>"],"background": {"scripts": ["background.js"]},"options_page": "options.html","browser_action": {"default_popup": "popup.html","default_icon": {"16": "icons/icon16.png","48": "icons/icon48.png","128": "icons/icon128.png"}},"icons": {"16": "icons/icon16.png","48": "icons/icon48.png","128": "icons/icon128.png"}
}

background.js

let customHeaders = {};chrome.runtime.onInstalled.addListener(() => {// Load headers from storage when the extension is installed or updatedchrome.storage.sync.get(['headers'], function(result) {if (result.headers) {customHeaders = result.headers;}});
});chrome.webRequest.onBeforeSendHeaders.addListener(function(details) {// Modify request headersfor (const [name, value] of Object.entries(customHeaders)) {let headerExists = false;for (let header of details.requestHeaders) {if (header.name.toLowerCase() === name.toLowerCase()) {header.value = value;headerExists = true;break;}}if (!headerExists) {details.requestHeaders.push({ name: name, value: value });}}return { requestHeaders: details.requestHeaders };},{ urls: ["<all_urls>"] },["blocking", "requestHeaders"]
);chrome.storage.onChanged.addListener(function(changes, namespace) {if (namespace === 'sync' && changes.headers) {customHeaders = changes.headers.newValue;}
});

options.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Extension Options</title><link rel="stylesheet" href="popup.css">
</head>
<body><h1>Modify HTTP Headers</h1><div id="headers-container"><div class="header-entry"><input type="text" placeholder="Header Name" class="header-name"><input type="text" placeholder="Header Value" class="header-value"><button class="remove-header">Remove</button></div></div><button id="add-header">Add Header</button><button id="save-headers">Save Headers</button><script src="options.js"></script>
</body>
</html>

options.js

document.addEventListener('DOMContentLoaded', function() {const headersContainer = document.getElementById('headers-container');const addHeaderButton = document.getElementById('add-header');const saveHeadersButton = document.getElementById('save-headers');addHeaderButton.addEventListener('click', function() {const headerEntry = document.createElement('div');headerEntry.className = 'header-entry';headerEntry.innerHTML = `<input type="text" placeholder="Header Name" class="header-name"><input type="text" placeholder="Header Value" class="header-value"><button class="remove-header">Remove</button>`;headerEntry.querySelector('.remove-header').addEventListener('click', function() {headerEntry.remove();});headersContainer.appendChild(headerEntry);});saveHeadersButton.addEventListener('click', function() {const headers = {};document.querySelectorAll('.header-entry').forEach(entry => {const name = entry.querySelector('.header-name').value;const value = entry.querySelector('.header-value').value;if (name && value) {headers[name] = value;}});chrome.storage.sync.set({headers: headers}, function() {alert('Headers saved');});});// Load saved headers on options page loadchrome.storage.sync.get(['headers'], function(result) {if (result.headers) {for (const [name, value] of Object.entries(result.headers)) {const headerEntry = document.createElement('div');headerEntry.className = 'header-entry';headerEntry.innerHTML = `<input type="text" value="${name}" class="header-name"><input type="text" value="${value}" class="header-value"><button class="remove-header">Remove</button>`;headerEntry.querySelector('.remove-header').addEventListener('click', function() {headerEntry.remove();});headersContainer.appendChild(headerEntry);}}});
});

popup.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Popup</title><link rel="stylesheet" href="popup.css">
</head>
<body><h1>Modify HTTP Headers</h1><button id="open-options">Open Options</button><script src="popup.js"></script>
</body>
</html>

popup.js

document.addEventListener('DOMContentLoaded', function() {document.getElementById('open-options').addEventListener('click', function() {chrome.runtime.openOptionsPage();});
});

popup.css

body {width: 200px;font-family: Arial, sans-serif;margin: 0;padding: 20px;box-sizing: border-box;
}h1 {font-size: 16px;margin: 0 0 20px;text-align: center;
}button {display: block;width: 100%;margin: 10px 0;padding: 10px;font-size: 14px;cursor: pointer;
}

加载和测试扩展

  1. 打开 Chrome 浏览器。
  2. 进入 chrome://extensions/ 页面。
  3. 打开右上角的“开发者模式”。
  4. 点击“加载已解压的扩展程序”按钮。
  5. 选择你的扩展所在的目录 my_chrome_extension

现在,你可以通过扩展的图标打开选项页面,添加或移除请求头。保存后,这些头会在所有的HTTP请求(包括AJAX请求)中被修改。

让我们详细解释一下这段 background.js 代码及其功能。

好的,让我们详细解释一下这段 background.js 代码及其功能。

代码解释

let customHeaders = {};// 当扩展程序安装或更新时加载存储的headers
chrome.runtime.onInstalled.addListener(() => {chrome.storage.sync.get(['headers'], function(result) {if (result.headers) {customHeaders = result.headers;}});
});// 拦截并修改请求头
chrome.webRequest.onBeforeSendHeaders.addListener(function(details) {// 修改请求头for (const [name, value] of Object.entries(customHeaders)) {let headerExists = false;for (let header of details.requestHeaders) {if (header.name.toLowerCase() === name.toLowerCase()) {header.value = value;headerExists = true;break;}}if (!headerExists) {details.requestHeaders.push({ name: name, value: value });}}return { requestHeaders: details.requestHeaders };},{ urls: ["<all_urls>"] },["blocking", "requestHeaders"]
);// 监听存储的变化
chrome.storage.onChanged.addListener(function(changes, namespace) {if (namespace === 'sync' && changes.headers) {customHeaders = changes.headers.newValue;}
});

详细解释

  1. 定义自定义请求头变量

    let customHeaders = {};
    

    定义一个空对象 customHeaders 来存储用户定义的自定义请求头。

  2. 扩展程序安装或更新时加载存储的请求头

    chrome.runtime.onInstalled.addListener(() => {chrome.storage.sync.get(['headers'], function(result) {if (result.headers) {customHeaders = result.headers;}});
    });
    

    当 Chrome 扩展程序安装或更新时,会触发 chrome.runtime.onInstalled 事件。此时,从 chrome.storage.sync 中获取存储的 headers 并将其赋值给 customHeaderschrome.storage.sync 是一个同步存储,可以在不同设备之间同步数据。

  3. 拦截并修改请求头

    chrome.webRequest.onBeforeSendHeaders.addListener(function(details) {
    

    使用 chrome.webRequest.onBeforeSendHeaders.addListener 方法拦截每个 HTTP 请求。

  4. 修改请求头

    for (const [name, value] of Object.entries(customHeaders)) {let headerExists = false;for (let header of details.requestHeaders) {if (header.name.toLowerCase() === name.toLowerCase()) {header.value = value;headerExists = true;break;}}if (!headerExists) {details.requestHeaders.push({ name: name, value: value });}
    }
    

    遍历 customHeaders 中的每个自定义请求头:

    • 如果在 details.requestHeaders 中找到相同名称的请求头,则修改其值。
    • 如果未找到相同名称的请求头,则添加新的请求头。
  5. 返回修改后的请求头

    return { requestHeaders: details.requestHeaders };
    

    返回修改后的请求头,确保新的请求头会被应用到实际的 HTTP 请求中。

  6. 监听存储变化

    chrome.storage.onChanged.addListener(function(changes, namespace) {if (namespace === 'sync' && changes.headers) {customHeaders = changes.headers.newValue;}
    });
    

    监听 chrome.storage 的变化,当 headers 发生变化时,更新 customHeaders。这使得用户可以通过扩展程序界面动态地修改自定义请求头,而不需要重新加载插件。

为什么要这么写

  • 自定义请求头存储与同步

    • 通过 chrome.storage.sync 存储自定义请求头,使其可以在不同设备之间同步。
    • 在扩展程序安装或更新时加载存储的请求头,确保扩展程序启动时使用最新的自定义请求头。
  • 拦截和修改请求头

    • 使用 chrome.webRequest.onBeforeSendHeaders 拦截每个 HTTP 请求,并在请求发送之前修改请求头,实现灵活的请求头修改。
  • 动态更新自定义请求头

    • 监听 chrome.storage.onChanged 事件,实时更新 customHeaders,使得用户可以动态地修改请求头,而不需要重新加载插件。

通过这种方式,用户可以在扩展程序界面灵活地设置和修改 HTTP 请求头,适用于各种不同的需求,且这些设置可以在不同设备之间同步。

这篇关于写一个chrome插件,统一修改所有http请求的header头,包括ajax请求的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1083193

相关文章

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存