ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

使用微软的FCI/FDI库进行文件压缩

2022-02-17 07:31:34  阅读:246  来源: 互联网

标签:HFCI DIAMONDAPI 微软 FDI BOOL context FCI


 

简介:
FCI(File Compression Interface)和FDI(File Decompression Interface)是由微软提供的用于压缩和解压缩的开发包。最大的好处是在WinNT、Win2000、WinXP下系统都提供了相应的API接口。所以,我们的程序不需要额外的压缩库。
本文附带例程只是给大家展示了一些比较简单的用法,大家可以根据微软提供的文档,自己挖掘其他的更强大功能。

API介绍:
FCI/FDI API 用到大量的回调函数,具体函数的原型定义大家可以参考头文件。

 一、 FCI

FCI包括5个API。
FCICreate 创建 FCI context
FCIAddFile 向 cabinet 中添加文件
FCIFlushCabinet 结束当前的 cabinet
FCIFlushFolder 结束当前的folder 并建立新的 folder
FCIDestroy 销毁 FCI context

HFCI DIAMONDAPI FCICreate(
	PERF              perf,       	//用于返回错误类型
	PFNFCIFILEPLACED  pfnfiledest,	//用在一个文件跨越多个cabinet时
      	PFNFCIALLOC       pfnalloc,   	//用来分配和释放内存。
      	PFNFCIFREE        pfnfree,
      	PFNFCIOPEN        pfnopen,	//一下6个分别处理文件的创建、读写、
      	PFNFCIREAD        pfnread,	//关闭、定位以及删除等。
      	PFNFCIWRITE       pfnwrite,
      	PFNFCICLOSE       pfnclose,
      	PFNFCISEEK        pfnseek,
	PFNFCIDELETE      pfndelete,
     	PFNFCIGETTEMPFILE pfnfcigtf,	//用于产生临时文件名
      	PCCAB             pccab,	//是一个CCAB结构的指针对压缩文件的详细描述
					//比如:大小、名称、路径等。
	void FAR *        pv            //返回一些context 参数。
);

BOOL DIAMONDAPI FCIAddFile(
	HFCI                 hfci,	//由FCICreate创建的context
     	char                 *pszSourceFile,//被压缩的文件
     	char                 *pszFileName,//此文件在压缩包中的名称
     	BOOL                  fExecute,    //解压时文件是否执行
     	PFNFCIGETNEXTCABINET  GetNextCab,//创建下一个cabinet时调用,这里忽略
     	PFNFCISTATUS          pfnProgress,//周期性的回调函数,可以显示压缩的进度。
     	PFNFCIGETOPENINFO     pfnOpenInfo,//打开文件返回文件句柄及属性
    	TCOMP                 typeCompress   //压缩的类型
)

BOOL DIAMONDAPI FCIFlushCabinet(
	HFCI                  hfci,          //由FCICreate创建的context
      	BOOL                  fGetNextCab, //决定GetNextCab是否被调用
      	PFNFCIGETNEXTCABINET  GetNextCab,//当cabinet满的时候调用
      	PFNFCISTATUS          pfnProgress //同FCIAddFile
)

BOOL DIAMONDAPI FCIFlushFolder(
	HFCI                  hfci,           //参数同上
	PFNFCIGETNEXTCABINET  GetNextCab,
	PFNFCISTATUS          pfnProgress
)
		
BOOL DIAMONDAPI FCIDestroy(
	HFCI	hfci
)

 二、 FDI

FDI包括4个API。
FDICreate 创建 FDI context
FDIIsCabinet 判断是否为CAB压缩文件,是则返回其属性
FDICopy 解压
FDIDestroy 销毁 FDI context

HFCI DIAMONDAPI FDICreate(//参数与FCI相应参数差不多
	PFNALLOC 		pfnalloc,
	PFNFREE 		pfnfree,
	PFNOPEN 		pfnopen,
	PFNREAD 		pfnread,
	PFNWRITE 		pfnwrite,
	PFNCLOSE		pfnclose,
	pfnseek,
	int			cpuType,// CPU类型,32位FDI忽略此参数
	PERF			perf
)

BOOL DIAMONDAPI FDIIsCabinet(
	HFDI 			hfdi,        //FDI context
	int 			hf,              //打开的文件句柄
	PFDICABINETINFO 	pfdici   //返回压缩文件的一些属性
)

BOOL FAR DIAMONDAPI FDICopy(
	HFDI          hfdi,
	char FAR     *pszCabinet, //待解压文件名
	char FAR     *pszCabPath, //待解压文件的路径
	int           flags,      //保留,现在必须为0
	PFNFDINOTIFY  pfnfdin,    //回调函数,用来处理FDI的通知
	PFNFDIDECRYPT pfnfdid,    //保留,现在必须为NULL
	void FAR     *pvUser      //作为参数传给回调函数pfnfdin,这里设为NULL
)


注意事项:
1、 用到的库CABINET.DLL,在安装操作系统时已经有了。我们可以用它生成lib库。

2、 一个context只能在创建他的线程使用,如果要使用多线程必须创建多个context

【转】https://blog.csdn.net/fjclc2008/article/details/6943485

标签:HFCI,DIAMONDAPI,微软,FDI,BOOL,context,FCI
来源: https://www.cnblogs.com/hshy/p/15903026.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有