在websocket中解码延续帧

时间:2013-04-02 17:07:46

标签: javascript node.js websocket

如何解码websocket中的延续帧?有人可以给我一个有用的见解吗?将连续帧解码为文本框会导致错误。

我正在向服务器发送一个大的文本字符串,我可以设法只解码第一个传入的文本框,然后失败。

这是nodejs中一个处理文本帧解码的简单函数 -

function decodeWS(data)
{
    var dl = data[1] & 127;
    var ifm = 2;
    if (dl == 126) 
    {
        ifm = 4;
    } else if (dl == 127) 
    {
        ifm = 10;
    }
    var i = ifm + 4;
    var masks = data.slice(ifm,i);
    var index = 0;
    var output = "";
    var l=data.length;
    while (i < l) 
    {
        output += String.fromCharCode(data[i++] ^ masks[index++ % 4]);
    }
    return output;
}

1 个答案:

答案 0 :(得分:1)

获取特定的帧位

Fin Bit

bool fin = (data[0] & 128) == 128;

的OpCode

int opCode = data[0] & 15;

IsMasked

bool isMasked = (data[1] & 128) == 128;

数据长度

int dataLength = data[1] & 127;

Websocket框架概述

0                   1                   2                   3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-------+-+-------------+-------------------------------+
|F|R|R|R| opcode|M| Payload len |    Extended payload length    |
|I|S|S|S|  (4)  |A|     (7)     |             (16/64)           |
|N|V|V|V|       |S|             |   (if payload len==126/127)   |
| |1|2|3|       |K|             |                               |
+-+-+-+-+-------+-+-------------+ - - - - - - - - - - - - - - - +
|     Extended payload length continued, if payload len == 127  |
+ - - - - - - - - - - - - - - - +-------------------------------+
|                               |Masking-key, if MASK set to 1  |
+-------------------------------+-------------------------------+
| Masking-key (continued)       |          Payload Data         |
+-------------------------------- - - - - - - - - - - - - - - - +
:                     Payload Data continued ...                :
+ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +
|                     Payload Data continued ...                |
+---------------------------------------------------------------+

关于如何获取字节的特定位的一般信息

示例:获取FIN位

首先记下第一个字节的二进制表示,让我们假设第一个比特是130,所以二进制中的1000 0010或更易理解的Fin比特集和二进制数据的opCode 2。 如果您希望获得最重要的位,则需要将逻辑AND(&amp;)运算符与128(二进制中为1000 0000)一起使用。

所以基本上1和1将是1,其他一切都将是0。

1000 0010 -> First Byte
1000 0000 -> Our Masking Byte => 128 in Decimal
---------
1000 0000 -> Resulting Byte => 128 in Decimal (Fin bit set)

未设置另一个示例Fin位和文本数据。

0000 0001 -> First Byte
1000 0000 -> Our Masking Byte -> 128 in Decimal
---------
0000 0000 -> Resulting Byte => 0 in Decimal (Fin bit not set)

示例:获取OpCode(OpCode告诉您此框架的用途)

可以从第一个字节的前4位收集OpCode。假设FIN位已设置且OpCode为Text。

1000 0001 -> First Byte
0000 1111 -> Our Masking Byte => 15 in Decimal
---------
0000 0001 -> Resulting Byte => 1 in Decimal (Text OpCode)