要检索通过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/