mirror of
https://github.com/apache/httpd.git
synced 2025-08-04 05:42:12 +03:00
Fix bit-shifting of websockets frame fields that would yield wrong opcodes
when the FIN bit was set. Results in PING not being recognized by mod_lua. PR57524 Submitted By: Edward Lu Committed By: covener git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1657256 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
@ -2252,9 +2252,12 @@ static int lua_websocket_read(lua_State *L)
|
||||
rv = lua_websocket_readbytes(r->connection, &byte, 1);
|
||||
}
|
||||
if (rv == APR_SUCCESS) {
|
||||
unsigned char fin, opcode, mask, payload;
|
||||
fin = byte >> 7;
|
||||
opcode = (byte << 4) >> 4;
|
||||
unsigned char ubyte, fin, opcode, mask, payload;
|
||||
ubyte = (unsigned char)byte;
|
||||
/* fin bit is the first bit */
|
||||
fin = ubyte >> (CHAR_BIT - 1);
|
||||
/* opcode is the last four bits (there's 3 reserved bits we don't care about) */
|
||||
opcode = ubyte & 0xf;
|
||||
|
||||
/* Get the payload length and mask bit */
|
||||
if (plaintext) {
|
||||
@ -2264,14 +2267,18 @@ static int lua_websocket_read(lua_State *L)
|
||||
rv = lua_websocket_readbytes(r->connection, &byte, 1);
|
||||
}
|
||||
if (rv == APR_SUCCESS) {
|
||||
mask = byte >> 7;
|
||||
payload = byte - 128;
|
||||
ubyte = (unsigned char)byte;
|
||||
/* Mask is the first bit */
|
||||
mask = ubyte >> (CHAR_BIT - 1);
|
||||
/* Payload is the last 7 bits */
|
||||
payload = ubyte & 0x7f;
|
||||
plen = payload;
|
||||
|
||||
/* Extended payload? */
|
||||
if (payload == 126) {
|
||||
len = 2;
|
||||
if (plaintext) {
|
||||
/* XXX: apr_socket_recv does not receive len bits, only up to len bits! */
|
||||
rv = apr_socket_recv(sock, (char*) &payload_short, &len);
|
||||
}
|
||||
else {
|
||||
|
Reference in New Issue
Block a user