gpt4 book ai didi

java - 在 Java 中读取 gzip 压缩的分块数据 HTTP 1.1

转载 作者:可可西里 更新时间:2023-11-01 17:05:49 27 4
gpt4 key购买 nike

我正在尝试使用 gzip 数据 + 分块编码获取 HTTP 请求的正文。我使用的代码:

byte[] d; // *whole* request body

ByteArrayOutputStream b = new ByteArrayOutputStream();

int c = 0;
int p = 0;

int s = 0;

for(int i = 0; i < d.length; ++i) {
if (s == 0 && d[i] == '\r' && d[i + 1] == '\n') {
c = Integer.parseInt(new String(Arrays.copyOfRange(d, p+1, i)), 16);

if(c == 0) break;

b.write(Arrays.copyOfRange(d, i+2, i+2+c));

p = i + 1;
i += c + 1;

s = 1;
} else if (s == 1 && d[i] == '\r' && d[i + 1] == '\n') {
p = i + 1;
s = 0;
}
}

// here comes the part where I decompress b.toByteArray()

简而言之,程序读取 block 大小并将整个请求的一部分(从'\n'到'\n'+ block 大小)写入ByteArrayOutputStream b并重复该过程直到找到大小为 0 的 block 。

如果我尝试解压缩此类数据,我总是会收到一些损坏的数据警告,例如java.util.zip.ZipException:距离太远无效

有没有想过我可能做错了什么?

最佳答案

强制性序言:在专业环境中,我总是为此使用库。参见 Apache HttpComponents例如,它将为您处理(以及更多)。如果您不想要库并且喜欢冒险,可以在 JRE 中找到 sun.net.www.http.ChunkedInputStream

此外,在专业上下文中,描述性变量名称将是首选:)

无论如何,我看到一个错误:p 应该用-1 初始化,而不是0

似乎就这些了,因为通过该修复我可以解码以下内容(由 Wikipedia 提供):

4\r\n
Wiki\r\n
5\r\n
pedia\r\n
E\r\n
in\r\n
\r\n
chunks.\r\n
0\r\n
\r\n

进入这个:

Wikipedia in

chunks.

(是的,这是预期的输出,请参阅维基百科页面)。

如果你将p初始化为0,那么你第一次需要用它来读取4时,你正在使用 p+1 所以它指向 4

我知道我的例子没有压缩,但我的意思是错误出在读取第一个 block 大小的代码中,所以这应该无关紧要......幸运的是,这将是唯一的错误。

关于java - 在 Java 中读取 gzip 压缩的分块数据 HTTP 1.1,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44066276/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com