尝试解压缩 gzip 编码的 http 响应。将以下内容传递给解压缩器:
gd.decompressGZIP(response.split("\r\n\r\n")[1].getBytes());
此代码分割响应并将后一部分(gzip 编码内容)发送到 decompressGZIP 函数。 “response”变量是一个字符串,其中包含完整的 htpp 响应。解压器代码如下。
String decompressGZIP(byte[] gzip) throws IOException {
java.io.ByteArrayInputStream bytein = new java.io.ByteArrayInputStream(gzip);
java.util.zip.GZIPInputStream gzin = new java.util.zip.GZIPInputStream(bytein);
java.io.ByteArrayOutputStream byteout = new java.io.ByteArrayOutputStream();
int res = 0;
byte buf[] = new byte[1024];
while (res >= 0) {
res = gzin.read(buf, 0, buf.length);
if (res > 0) {
byteout.write(buf, 0, res);
}
}
return (new String(byteout.toByteArray()));
}
但是,我遇到了如下异常:
Sep 03, 2013 9:19:04 PM ownproxy.ProxyThread2 run
SEVERE: null
java.util.zip.ZipException: Not in GZIP format
at java.util.zip.GZIPInputStream.readHeader(GZIPInputStream.java:164)
at java.util.zip.GZIPInputStream.<init>(GZIPInputStream.java:78)
at java.util.zip.GZIPInputStream.<init>(GZIPInputStream.java:90)
at ownproxy.GZIPDecompress.decompressGZIP(GZIPDecompress.java:18)
at ownproxy.ProxyThread2.run(InterceptionProxy2.java:84)
数据似乎不是gzip 格式。谁能告诉我我做错了什么?
最佳答案
您正在尝试将转换为字节的文本解压缩为 GZIP 压缩流,但事实并非如此。当您将二进制编码为文本时,它通常会被破坏并且信息会丢失且无法恢复。
GZIP 流有一个特定的 header 和末尾的 CRC32 校验和。如果没有这些,它就不是有效的格式。
Can anyone tell me what I'm doing wrong?
当您将二进制转换为文本并再次转换回来时,您不会得到开始时的结果。不要这样做。您必须将二进制文件保留为二进制文件,而不是将其转换为文本。
关于java - GZIP解压代码抛出异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18577060/