我一直在寻找一种方法来改变我在浏览器中发出的XHR请求,然后再次重播。 假设我在浏览器中完成了一个完整的POST请求,我唯一想要更改的是一个小值,然后再次播放。直接在浏览器中执行操作会更容易,更快捷。
我已经谷歌了,并且还没有找到在Chrome或Firefox中执行此操作的方法。有没有办法在这些浏览器中的任何一个浏览器中执行,或者可能是另一个浏览器?
答案 0 :(得分:113)
Chrome:
curl
命令见捕获:
或者,如果您需要在网页上下文中发送请求,请选择"复制为提取" 并编辑发送来自javascript控制台面板的内容。
Firefox:
Firefox允许直接从“网络”面板编辑和重新发送XHR。以下捕获来自Firefox 36:
答案 1 :(得分:16)
我的两点建议:
Chrome's Postman plugin + Postman Interceptor Plugin。更多信息:Postman Capturing Requests Docs
如果你在Windows上,那么Telerik的Fiddler就是一个选择。它有一个用于重放http请求的composer选项,它是免费的。
答案 2 :(得分:14)
Chrome现在在版本67中复制为提取:
复制为提取
右键点击网络请求,然后选择复制>复制为提取,将该请求的
fetch()
- 等效代码复制到剪贴板。
https://developers.google.com/web/updates/2018/04/devtools#fetch
示例输出:
fetch("https://stackoverflow.com/posts/validate-body", {
credentials: "include",
headers: {},
referrer: "https://stackoverflow.com/",
referrerPolicy: "origin",
body:
"body=Chrome+now+has+_Copy+as+fetch_+in+version+67%3A%0A%0A%3E+Copy+as+fetch%0ARight-click+a+network+request+then+select+**Copy+%3E+Copy+As+Fetch**+to+copy+the+%60fetch()%60-equivalent+code+for+that+request+to+your+clipboard.%0A%0A&oldBody=&isQuestion=false",
method: "POST",
mode: "cors"
});
不同之处在于 Copy as cURL 还将包含所有请求标头(例如Cookie和Accept),并且适合在Chrome之外重播请求。 fetch()
代码适合在同一浏览器内重播。
答案 3 :(得分:8)
答案 4 :(得分:2)
答案 5 :(得分:1)
对于Firefox,问题解决了。它有"编辑和重新发送"功能实现。
对于Chrome Tamper extension似乎可以解决问题。
答案 6 :(得分:0)
如上所述,有几种方法可以执行此操作,但是以我的经验,处理XHR请求并重新发送的最佳方法是使用chrome dev工具将请求复制为cURL请求(在网络标签),然后简单地导入Postman应用程序(左上方的巨型导入按钮)。
答案 7 :(得分:0)
答案 8 :(得分:0)