zlib 在没有 DICTID 和 ADLER32 校验和的情况下膨胀

zlib inflate without DICTID and ADLER32 checksum nodejs

我正在尝试使用 NodeJs 中的 zlib 模块扩充缓冲区。我遇到的问题是我总是遇到“意外的文件结尾”错误,所以我使用了我的原始数据并让 nodejs 对其进行压缩以比较字节值。

(1) 所以这是我的价值:

120, 156, 106, 46, 97, 96, 96, 96, 73, 97, 96, 76, 1, 49, 152, 82, 24, 216, 226, 75, 138, 18, 147, 83, 115, 128, 60, 198, 92, 32, 161, 17, 173, 148, 158, 88, 146, 90, 158, 88, 169, 91, 80, 148, 162, 155, 155, 152, 153, 167, 91, 104, 96, 94, 172, 164, 83, 173, 148, 155, 153, 92, 148, 95, 172, 100, 101, 160, 103, 80, 27, 155, 149, 194, 32, 148, 145, 154, 88, 84, 146, 148, 154, 88, 18, 159, 153, 87, 146, 90, 84, 150, 152, 147, 196, 192, 176, 80, 41, 133, 129, 41, 191, 32, 145, 11, 104, 75, 113, 10, 3, 115, 94, 102, 14, 144, 85, 2, 97, 1, 0, 0, 0, 255, 255

(2) 这就是 zlib.deflateSync 给我的:

120, 156, 1, 125, 0, 130, 255, 120, 156, 106, 46, 97, 96, 96, 96, 73, 97, 96, 76, 1, 49, 152, 82, 24, 216, 226, 75, 138, 18, 147, 83, 115, 128, 60, 198, 92, 32, 161, 17, 173, 148, 158, 88, 146, 90, 158, 88, 169, 91, 80, 148, 162, 155, 155, 152, 153, 167, 91, 104, 96, 94, 172, 164, 83, 173, 148, 155, 153, 92, 148, 95, 172, 100, 101, 160, 103, 80, 27, 155, 149, 194, 32, 148, 145, 154, 88, 84, 146, 148, 154, 88, 18, 159, 153, 87, 146, 90, 84, 150, 152, 147, 196, 192, 176, 80, 41, 133, 129, 41, 191, 32, 145, 11, 104, 75, 113, 10, 3, 115, 94, 102, 14, 144, 85, 2, 97, 1, 0, 0, 0, 255, 255, 164, 112, 54, 45, (粗体 = 相同)

据我所知 RFC 前两个字节是压缩方法和标志,因此两者都有。另一个粗体部分是压缩数据。到目前为止一切顺利。

不匹配的第一部分是 DICTID 部分。但根据 RFC,它只有四个字节长,那么其他三个字节(255、120、156)是什么?最后不加粗的部分是压缩数据的ADLER32校验和。

问题:zlib (nodejs) 是否能够在没有 DICTID 和 ADLER32 校验和的情况下以某种方式膨胀数据?

当前代码片段:

const data = /* Array from (1) */;
const buffer = Buffer.from(data);
const out = zlib.inflateSync(buffer);

输出Error: unexpected end of file

背景:我最终想做的事情 is the following 但在 javascript 而不是 python.

注意:命令行程序 zlib-flate 能够以某种方式膨胀 (1) 中的字节,所以我假设我做错了什么。

经过几个小时的跟踪和错误,我终于弄清楚了问题所在。 为了能够膨胀 (1) 中的字节,您必须设置 finishFlush 选项:

const result = zlib.inflateSync(buffer, {finishFlush: zlib.constants.Z_SYNC_FLUSH});