瀏覽代碼

Fix the algorithm for decoding the remaining length to allow a length greater than 2,097,151 bytes.

See: https://docs.oasis-open.org/mqtt/mqtt/v3.1.1/errata01/os/mqtt-v3.1.1-errata01-os.html#_Toc442180732
release/3.x.x
kpreisser 6 年之前
父節點
當前提交
88de5047bc
共有 1 個文件被更改,包括 2 次插入2 次删除
  1. +2
    -2
      Frameworks/MQTTnet.NetStandard/Serializer/MqttPacketReader.cs

+ 2
- 2
Frameworks/MQTTnet.NetStandard/Serializer/MqttPacketReader.cs 查看文件

@@ -86,7 +86,7 @@ namespace MQTTnet.Serializer

private static async Task<int> ReadBodyLengthFromSourceAsync(Stream stream, CancellationToken cancellationToken)
{
// Alorithm taken from http://docs.oasis-open.org/mqtt/mqtt/v3.1.1/os/mqtt-v3.1.1-os.html.
// Alorithm taken from https://docs.oasis-open.org/mqtt/mqtt/v3.1.1/errata01/os/mqtt-v3.1.1-errata01-os-complete.html.
var multiplier = 1;
var value = 0;
byte encodedByte;
@@ -110,11 +110,11 @@ namespace MQTTnet.Serializer
readBytes.Add(encodedByte);

value += (byte)(encodedByte & 127) * multiplier;
multiplier *= 128;
if (multiplier > 128 * 128 * 128)
{
throw new MqttProtocolViolationException($"Remaining length is invalid (Data={string.Join(",", readBytes)}).");
}
multiplier *= 128;
} while ((encodedByte & 128) != 0);

return value;


Loading…
取消
儲存