请问有没有什么方式可以获取所有浏览器请求的 XHR response 保存到文件?

2022-09-07 11:13:23 +08:00
 idealhs

比如刚打开 v2 就 get 的 www.v2ex.com/api/nodes/list.json 返回了一个 jarray,是一个节点的 list 。我想开发一个浏览器插件或者油猴脚本,能够自动将浏览过程中所有返回的 XHR 保存到本地文件中,有什么思路吗?

1445 次点击
所在节点    问与答
7 条回复
renmu
2022-09-07 11:26:30 +08:00
写个抓包软件,把来自浏览器的请求写入文件。插件和油猴够呛,好像都没有访问本地文件的权限吧
iannil
2022-09-07 11:29:00 +08:00
fiddler
Rache1
2022-09-07 11:29:27 +08:00
用油猴重写相关函数、对象:XMLHTTPRequest 、fetch ,自己写可能比较麻烦,可以找一些现成的 ajax hook 包。
idealhs
2022-09-07 11:29:34 +08:00
@renmu 本地文件好像油猴都可以,有一个 FileSaver.js 我试了可以直接变成下载,放下载目录我也 OK 的。 不过抓包软件确实好像更好一点?
Doraismydora
2022-09-07 11:32:22 +08:00
接管浏览器代理, 然后请求的时候保存到内存, 关闭标签页或者请求下载的时候弄个 blob 下下来
Vegetable
2022-09-07 11:35:19 +08:00
油猴做过一个 hook xhr 的,保存文件应该也行吧,不知道油猴有没有持续写文件的能力,总不能过一会儿下载一下。

你这个多少得有点后续要求吧,比如筛选特定请求之类的,可以考虑 mitmproxy 之类的可以比较方便编写代理脚本的。如果是一次性的直接用 fiddler 这种另存为就好了。
eason1874
2022-09-07 11:44:29 +08:00
我做过,chrome 扩展不行,firefox 扩展可以 filter 所有请求,判断一下类型再转存就好了。转存用下载文件不好用,因为你还得二次整理。你干脆在本地开一个 HTTP 服务,拿到数据了 POST 过去,由它进行整理入库

API: https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/webRequest
例子: https://github.com/mdn/webextensions-examples/tree/master/http-response

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/878305

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX