是否有一种方法或扩展,让我观察“流量”通过WebSocket?出于调试目的,我希望看到客户端和服务器的请求/响应。
Chrome开发工具允许看到握手请求在打开连接期间保持等待,但据我所知,你不能看到流量。但是你可以嗅嗅它为例。
Chrome开发工具现在有能力列出WebSocket帧,也检查数据,如果帧不是二进制的。
过程:
如果您的WebSocket连接使用二进制帧,那么您可能仍然需要使用Wireshark来调试连接。Wireshark 1.8.0为WebSockets增加了解析器和过滤支持。可以在其他的答案中找到替代方法。
Chrome Canary和Chromium现在有WebSocket消息帧检查功能。下面是快速测试的步骤:
请注意:每当你发送或接收新消息时,你必须通过点击左边的echo.websocket.org条目来刷新主面板。
我还发布了带有屏幕截图和视频的步骤。
我最近出版的书,HTML5 WebSocket的权威指南,也有一个专门的附录涵盖各种检查工具,包括Chrome Dev tools, Chrome net-internals和Wire Shark。
Chrome 29及以上版本的简短回答:
你有3个选项:Chrome(通过开发人员工具->网络选项卡),Wireshark和Fiddler(通过日志选项卡),但他们都非常基本。如果你有非常大的流量,或者每帧都非常大,使用它们进行调试就变得非常困难。
然而,你可以使用Fiddler和FiddlerScript来检查WebSocket流量,就像检查HTTP流量一样。这个解决方案的几个优点是,你可以利用Fiddler中的许多其他功能,如多个检查器(HexView, JSON, SyntaxView),比较数据包,并查找数据包等
请参考我最近在CodeProject上写的文章,这篇文章向你展示了如何用Fiddler(用FiddlerScript)调试/检查WebSocket流量。http://www.codeproject.com/Articles/718660/Debug-Inspect-WebSocket-traffic-with-Fiddler
如果你没有访问websocket的页面,你可以打开Chrome控制台并输入你的JavaScript:
var webSocket = new WebSocket('ws://address:port'); webSocket.onmessage = function(data) { console.log(data); }
这将打开web套接字,这样您就可以在网络选项卡和控制台中看到它。
其他答案涵盖了最常见的场景:观察帧的内容(开发人员工具->网络选项卡->右击websocket连接->帧)。
如果你想知道更多的信息,比如哪些套接字当前打开/空闲或能够关闭它们,你会发现这个url很有用
chrome://net-internals/#sockets
他们似乎在不断地改变Chrome中的东西,但这里是目前有效的:-)
WS
Frames
Messages
我使用的Chrome扩展名为简单WebSocket客户端v0.1.3,是由用户hakobera发布的。它的使用非常简单,它允许在给定的URL上打开websocket,发送消息并关闭socket连接。它非常简约。
我只是发布这篇文章,因为Chrome改变了很多,没有一个答案是最新的。
至于我开始使用的工具,我建议firecamp它像Postman,但它也支持websockets和socket.io。