Both the Jetty API and the JSR operate in the same way (on Jetty 9.1) with regards to streaming.
The first frame of an incoming WebSocket message will trigger the Streaming (if you specified as such with your OnMessage declaration).
It is your responsibility to read from that stream, meanwhile, any further incoming frames are pushed into the frame for you to read.
If you don't read fast enough, the WebSocket implementation pauses and lets you catch up. However, don't take too long, otherwise you might fall afoul of various timeouts.
Unlike other message handling, when a streaming onMessage occurs, it is dispatched to a new thread, rather than within the same thread that read/parsed the raw websocket frame. This allows jetty to continue reading and parsing for the purposes of streaming, and also allows the OnMessage thread to read from the stream.
The partial message support in the JSR is supported, and gladly the JSR spec makes no specifics on how it should work when extensions are in the mix. In other words, if you are using Chrome or Firefox, don't expect the frame boundaries you send will be the frame boundaries you receive.
We have no partial message support in the Jetty WebSocket API.
Why don't we expose this in the Jetty WebSocket API, but we do in the JSR?
The requirements of the
RFC 6455 with respect to TEXT messages and UTF8 encoding, means that it is very possible for partial message support to have odd behavior.
Example: you send a 1024 byte UTF8 message, it gets fragmented (for any of a dozen reasons), you receive a partial message of 30 bytes, then another of 2 bytes, then another 900 bytes, then finally the last 92 bytes. This is because a UTF-8 codepoint could be split by fragmentation, meaning that there is a partial codepoint that needs more data from the next frame in order to know if the TEXT message is valid per RFC-6455 or not.
With partial message support, it is also possible to start receiving a TEXT message, then have the
connection be forcibly failed due to some bad UTF-8 encoded data. This means you have to monitor the onError + onClose while using partial messages in order to know what just happened.
At least with streaming support, in this scenario you'll get IOExceptions and closed streams when the UTF-8 encoded data is invalid. A much cleaner approach to handling the non-happy-path scenarios.
Also note, none of these concerns apply for partial message handling of BINARY messages.