要检索通过gzip压缩的文件的未压缩大小,您可以读取最后四个字节。我这样做是为了查看是否有文件大小不应该达到的大小。如果文件小于应有的大小,则使用以下代码将其追加到文件中:

GZIPOutputStream gzipoutput = new GZIPOutputStream
    (new FileOutputStream(file, true));

while ((len=bs.read(buf)) >= 0) {
    gzipoutput.write(buf, 0, len);
}

gzipoutput.finish();
gzipoutput.close();


当然,这会按预期附加到gzip文件的末尾。但是,在追加之后,读取gzip文件的最后四个字节(以获取未压缩的文件大小)不会给我预期的结果。我怀疑这是因为使用GZIPOutputStream不能正确将大小字节附加到文件的末尾。

如何修改我的代码,以便附加正确的大小字节?

编辑

我正在按小端顺序读取字节,如下所示:

gzipReader.seek(gzipReader.length() - 4);
int byteFour = gzipReader.read();
int byteThree = gzipReader.read();
int byteTwo = gzipReader.read();
int byteOne = gzipReader.read();
// Now combine them in little endian
long size = ((long)byteOne << 24) | ((long)byteTwo << 16) | ((long)byteThree << 8) | ((long)byteFour);


我在想,因为我要追加到gzip文件,所以它只写入追加的字节,而不是总文件大小。这看似合理吗?

最佳答案

因为我要附加到gzip文件,所以它仅写入附加的字节,而不是总文件大小。这看似合理吗?


不仅是合理的,而且是不可避免的。看一下你的代码。追加GZIPOutputStream到底如何知道文件的先前大小?它只能看到传入的数据和传出的OutputStream.

关于java - GZIPOutputStream不更新Gzip大小字节,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25436895/

10-11 03:32
查看更多