去ZLIB官网下载最新版本1.2.11,自带minizip,在\contrib\minizip目录下面,由于zlib本身只是对字符串进行了编码压缩(有的人说zlib一次只能压缩一个文件,无法压缩多个文件,自己没有验证,不知道哪种说法正确),不满足直接打包压缩文件或文件夹的需求,需要对其进行封装,不过minizip可以实现这个效果(不过还是要用到zlib的,因为minizip是基于zlib的)。
一、linux环境
1。l根据https://blog.csdn.net/whahu1989/article/details/80344373介绍,在zlib1.2.11版本源码上,用gcc编译生成libz.so文件;
2.然后从\contrib\minizip目录拷贝ioapic.c、ioapic.h、unzip.c、unzip.h文件,从源码根目录拷贝crypt.h、zconf.h、zlib.h文件;
3.在程序里面增加如下代码,即可实现解压
#include "unzip.h"
unZipFile(char *czFileName, char *czUnZipFileName);
czFileName是zip文件名,czUnZipFileName是解压后的文件名
二、windows环境
1、zlib1.2.11版本,在\contrib\vstudio目录下面有zlib和minizip的VC++工程项目,支持VC++2008到VC++2015版本,用vc可以编译出zlib.dll和zlib.lib文件;
2.用VC编译要注意几个问题,
第一个要注意的问题,项目自带的三个配置: debug, release, releasewithoutasm,参考https://www.jianshu.com/p/f782f8cc77ee
debug build 的时候, 提示了 error LINK2026: 模块对于 SAFESEH 映像是不安全 的问题. 这时候, 打开工程属性->连接器->命令行, 输入 /SAFESEH:NO 到 附加选项 中即可.
relesae build 的时候, 无错误. 但是经过测试, 由于 release 分支使用了上面编译好的汇编代码. 上面也说过, 如果包含了这部分汇编的话, 解压缩的时候可能会再汇编代码这里引起内存崩溃的问题. 因此, 笔者没有用这个选项.
releasewithoutasm. 这个选项没有包含汇编, 测试过程中没有发生内存崩溃的问题.这个用个编译
第二个要注意的问题,在使用zlib1.2.11版本编译的dll,在使用的源码,要添加ZLIB_WINAPI宏,之前版本使用的ZLIB_DLL宏删除。
第三问题,在编译zlib时,提示在zconf.h文件的475行,无法打开包括文件: “unistd.h”。在475行,是#include
#ifdef _WIN32
# include
# include
#else
# include
#endif
编译通过。
三、另外,压缩文件应该类似,只需添加
#include "zip.h"
ZipFile(char *aczSrcFile,char *aczDesFile)
aczSrcFile,是待压缩的文件,aczDesFile是压缩后的zip文件。
四、压缩和解压2个函数源代码:
int ZipFile(char *aczSrcFile,char *aczDesFile)
{
FILE * f;
char *aczTmp;
int iLen;
zipFile pzipFile;
zip_fileinfo stzip_fileinfo;
f = fopen(aczSrcFile,"rb");
if (!f)
return -1998;
fseek(f,0L,SEEK_END);
iLen = ftell(f);
aczTmp = (char *)malloc(iLen+10);
memset(aczTmp,0,iLen+10);
fseek(f,0L,SEEK_SET);
iLen = fread(aczTmp,1,iLen,f);
fclose(f);
pzipFile = zipOpen(aczDesFile,0);
stzip_fileinfo.internal_fa = 0;
stzip_fileinfo.external_fa = 0;
zipOpenNewFileInZip(pzipFile,"data",&stzip_fileinfo,NULL,0,NULL,0,NULL,Z_DEFLATED ,Z_DEFAULT_COMPRESSION);
iLen = zipWriteInFileInZip(pzipFile,aczTmp,iLen);
zipCloseFileInZip(pzipFile);
zipClose(pzipFile,NULL);
free(aczTmp);
return iLen;
}
int unZipFile(char *aczSrcFile,char *aczDesFile)
{
int iRet;
FILE *f;
//char *aczTmp;
long iLen;
unz_file_info sInfo;
unzFile punzFile;
punzFile = unzOpen(aczSrcFile);
iRet = unzGoToFirstFile(punzFile);
if (iRet < 0)
{
unzClose(punzFile);
return iRet;
}
iRet = unzOpenCurrentFile(punzFile);
if (iRet < 0)
{
unzClose(punzFile);
return iRet;
}
iRet = unzGetCurrentFileInfo(punzFile,&sInfo,NULL,0,NULL,0,NULL,0);
if (iRet < 0)
{
unzCloseCurrentFile(punzFile);
unzClose(punzFile);
return iRet;
}
char aczTmp[10240];
f = fopen(aczDesFile,"wb");
if (!f)
{
return -1999;
}
while(true)
{
int size= unzReadCurrentFile(punzFile,aczTmp,sizeof(aczTmp));
if(size <= 0) { break; }
fwrite(aczTmp,1,size,f);
}
fclose(f);
unzCloseCurrentFile(punzFile);
unzClose(punzFile);
return iRet;
}