如何解码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;
}
答案 0 :(得分:1)
获取特定的帧位
bool fin = (data[0] & 128) == 128;
int opCode = data[0] & 15;
bool isMasked = (data[1] & 128) == 128;
int dataLength = data[1] & 127;
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)