我正在尝试以编程方式将gzip文件解压缩到内存中,并使用
libarchive project模拟命令gzip -d file.gz.
该文件实际上来自http响应,其标题为Accept-Encoding:gzip,deflate
在这里我尝试阅读该文件.我不希望不工作,因为gzip压缩文件没有条目(它被压缩为流)并且archive_read_next_header尝试从arcihve中读取下一个文件.
是否有任何替代此函数可以从压缩文件中提取整个数据.
archive_read_support_format_raw(archive);
archive_read_support_filter_all(archive);
archive_read_support_compression_all(archive)
archive_read_open_memory(archive, file_data, file_size);
struct archive_entry *entry;
la_ssize_t total, size;
char *buf;
int status = archive_read_next_header(archive, &entry);
也许有人可以发布解决此问题的最小代码示例?
此外,是否有一个选项可以找出gzip存档文件是否有条目?
最佳答案 一种可能的替代方法是使用boost :: iostreams库,它带有一个内置的gzip过滤器,可以准确地提供你想要的东西 – 从内存中的gzip文件流式解压缩.这是对
gzip filter的引用,以及来自相同的片段:
ifstream file("hello.gz", ios_base::in | ios_base::binary);
filtering_streambuf<input> in;
in.push(gzip_decompressor());
in.push(file);
boost::iostreams::copy(in, cout);
编辑:实际上这里有一个更好的片段https://stackoverflow.com/a/16693807/3656081