I am logging websocket traffic using Chrome/Developer Tools. I have no problem to view the websocket frames in network "Frames" window, but I can not save all frames (content enc. as JSON) in an external (text) file. I have already tried save as HAR and also simply used cntl A,C,V (first "page" copied only) but have so far not been very successful.
I am running Linux Mint 17.
Do you have hints how this can be done?
From a WebSocket request tab, click Save in the header(or, ⌘ + S ) to open the request save modal. You will notice that it asks to create a new collection for saving WebSocket requests. Click Create collection and name your new WebSocket collection. Finally, name your request and click Save.
Update for Chrome 63, January 2018
I managed to export them as JSON as this:
At this point, you can do whatever you want with the frames. I used the console.save
utility from https://bgrins.github.io/devtools-snippets/#console-save to save the frames as a JSON file (included in the snippet below).
// https://bgrins.github.io/devtools-snippets/#console-save (function(console){ console.save = function(data, filename){ if(!data) { console.error('Console.save: No data') return; } if(!filename) filename = 'console.json' if(typeof data === "object"){ data = JSON.stringify(data, undefined, 4) } var blob = new Blob([data], {type: 'text/json'}), e = document.createEvent('MouseEvents'), a = document.createElement('a') a.download = filename a.href = window.URL.createObjectURL(blob) a.dataset.downloadurl = ['text/json', a.download, a.href].join(':') e.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null) a.dispatchEvent(e) } })(console) // Frame/Socket message counter + filename var iter = 0; // This replaces the browser's `webSocketFrameReceived` code with the original code // and adds two lines, one to save the socket message and one to increment the counter. SDK.NetworkDispatcher.prototype.webSocketFrameReceived = function (requestId, time, response) { var networkRequest = this._inflightRequestsById[requestId]; if (!networkRequest) return; console.save(JSON.parse(response.payloadData), iter + ".json") iter++; networkRequest.addFrame(response, time, false); networkRequest.responseReceivedTime = time; this._updateNetworkRequest(networkRequest); }
This will save all incoming socket frames to your default download location.
From Chrome 76 the HAR file now includes WebSocket messages.
WebSocket messages in HAR exports
The _webSocketMessages
property begins with an underscore to indicate that it's a custom field.
... "_webSocketMessages": [ { "type": "send", "time": 1558730482.5071473, "opcode": 1, "data": "Hello, WebSockets!" }, { "type": "receive", "time": 1558730482.5883863, "opcode": 1, "data": "Hello, WebSockets!" } ] ...
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With