火狐浏览器控制台监听拦截所有Fetch异步请求并注入假数据
时间:2026-06-08 | 作者:318050 | 阅读:0要在火狐浏览器里玩转 Mock 数据,前端开发中经常遇到这么个场景:需要通过控制台监听并拦截所有 Fetch 请求,绕过真实后端,返回我们自定义的假数据。
问题在于,直接在控制台里执行代码,充其量只是临时劫持了 window.fetch,页面一刷新就失效了。而且控制台环境的限制导致我们无法持久性地重写这个核心函数,每次都得重新来一遍。
那么,真正可行的方案是什么?注入内容脚本,在页面加载之前完成函数劫持。这才是关键所在。
准备可运行的轻量级Mock扩展
先新建一个空文件夹,比如叫 mock-fetch-ext,作为临时扩展的根目录。这个文件夹里需要创建一个名为 manifest.json 的文件,内容如下:
{"manifest_version": 2,"name": "Fetch Mock Injector","version": "1.0","content_scripts": [{"matches": ["
注意,这一步不能跳过:run_at 必须设置为 document_start。为什么?因为一旦页面脚本开始执行,fetch 函数可能已经被调用了,这时候再去劫持就晚了,等于白忙一场。
编写核心劫持脚本 mock-inject.js
在同目录下新建一个 mock-inject.js 文件,粘贴以下核心代码:
const originalFetch = window.fetch;window.fetch = async function(input, init) {const url = input instanceof Request input.url : input;if (url.includes('/api/') || url.startsWith('https://example.com/api')) {return Promise.resolve(new Response(JSON.stringify({code: 0,data: {id: 999,name: "Mock User",timestamp: Date.now()}}),{status: 200,headers: {"Content-Type": "application/json"}}));}return originalFetch.apply(this, arguments);};
这里有个容易踩的坑:正则表达式或者 includes 的判断逻辑必须精准覆盖你目标接口的真实路径特征。比如说,你的接口路径是 /v1/user 或者是 /graphql,那就得写成 url.includes('/v1/') 或者 url.includes('/graphql')。千万别偷懒只写个 url.includes('/') —— 那可就糟糕了,它会拦截所有请求,包括字体、图片、CSS 文件,页面很可能会直接挂掉。
在火狐中临时加载并启用该扩展
搞定了脚本,接下来就是加载扩展了。
第一步:在地址栏输入 about:debugging#/runtime/this-firefox,然后回车。
第二步:点击右上角的「临时载入扩展」按钮 → 选择刚才创建的那个 mock-fetch-ext 文件夹 → 点击「打开」。
第三步:确认扩展列表中间出现「Fetch Mock Injector」并且状态显示为「已启用」。
第四步:打开目标网页,按 Ctrl+Shift+I 打开开发者工具 → 切换到「控制台」→ 执行 fetch('/api/user').then(r => r.json()).then(console.log)。

此时,控制台应该立刻输出你设定的 mock 数据对象。有意思的是,即使你在 Network 面板里看,这个请求依然存在,但响应体已经被偷偷替换了,状态码维持 200。这就是持久化 Mock 的精髓。
来源:整理自互联网
免责声明:文中图文均来自网络,如有侵权请联系删除,心愿游戏发布此文仅为传递信息,不代表心愿游戏认同其观点或证实其描述。
相关文章
更多-
- 火狐浏览器ESR 115版单标签页最大内存配额限制方法
- 时间:2026-06-08
-
- 火狐浏览器about:config关闭后台数据遥测教程
- 时间:2026-06-08
-
- 企业火狐浏览器policies.json静默预设主页方法
- 时间:2026-06-08
-
- 火狐浏览器无痕浏览模式设置方法
- 时间:2026-06-08
-
- 火狐浏览器无法播放视频的原因与解决方法
- 时间:2026-06-08
-
- 批处理脚本静默安全清理火狐所有用户历史缓存
- 时间:2026-06-08
-
- 火狐浏览器提示连接不安全且无法手动添加例外原因
- 时间:2026-06-07
-
- 火狐浏览器清理HTTPS缓存与加密连接数据管理
- 时间:2026-06-07
精选合集
更多大家都在玩
大家都在看
更多-
- AutoCAD 2007面域工具使用教程与操作详解
- 时间:2026-06-07
-
- AutoCAD 2007环形阵列功能使用教程详解
- 时间:2026-06-07
-
- 受欢迎的跳跃游戏合集
- 时间:2026-06-07
-
- nero光盘刻录软件使用教程详解
- 时间:2026-06-07
-
- foobar2000中文界面设置详细教程
- 时间:2026-06-07
-
- 知网百科知识查询与学术检索官网入口指南
- 时间:2026-06-07
-
- 雷电模拟器退出时最小化到托盘设置方法
- 时间:2026-06-07
-
- 雷电模拟器4核CPU性能优化设置教程
- 时间:2026-06-07