RFR: 8351339: WebSocket::sendBinary assume that user supplied buffers are BIG_ENDIAN [v7]

Mark Sheppard msheppar at openjdk.org
Wed Mar 26 00:24:08 UTC 2025


On Tue, 25 Mar 2025 20:49:20 GMT, Chen Liang <liach at openjdk.org> wrote:

>> Volkan Yazici has updated the pull request incrementally with three additional commits since the last revision:
>> 
>>  - Add more tests
>>  - Guard vectorization better
>>  - Restore the old garbage-free state
>
> src/java.net.http/share/classes/jdk/internal/net/http/websocket/Frame.java line 201:
> 
>> 199:             final int srcLim = src.limit(), dstLim = dst.limit();
>> 200:             int i = src.position(), j = dst.position();
>> 201:             for (; i < srcLim && j < dstLim;
> 
> I meant the endian issue is in this loop - the endianness of maskBytes (currently BE) must match that of dst (all internal usages of dst is currently BE). A safeguard would be nice here.

should the Endian check be in the genesis of the processing i.e. the applyMask method ?

        static void applyMask(ByteBuffer src, ByteBuffer dst, int mask) {

// endian check here then other checks are superfluous ?

            if (src.remaining() > dst.remaining()) {
                throw new IllegalArgumentException(dump(src, dst));
            }
            new Masker().setMask(mask).applyMask(src, dst);
        }

Additionally, if the WebSocket spec (RFC 6455) expects that data is sent (received) in network byte order (Big Endian), then both src and dst should be ByteOrder.BIG_ENDIAN  rather than just the same byte order ?

-------------

PR Review Comment: https://git.openjdk.org/jdk/pull/24033#discussion_r2013101494


More information about the net-dev mailing list