unrar.dll 使用实例

  1 /*
  2  * main.cpp
  3  *
  4  *  Created on: Aug 17, 2015
  5  *      Author: smallcroco
  6  *
  7  *  Discription:
  8  *      1 首先打开解压包,可以设置打开方式,获得句柄;
  9  *              RAROpenArchive函数,需要RAROpenArchiveData结构体
 10  *        或者
 11  *              RAROpenArchiveEx函数,需要RAROpenArchiveDataEx结构体
 12  *
 13  *      2 然后设置回调函数;
 14  *              RARSetCallback函数,需要设置回调函数
 15  *
 16  *      3 读取文件头,并判断是否解压完成;
 17  *              RARReader函数,需要RARHeaderData结构体
 18  *        或者
 19  *              RARReaderEx函数,需要RARHeaderDataEx结构体
 20  *
 21  *      4 跳到下一个文件;
 22  *              RARProcessFile函数
 23  *        或者
 24  *              RARProcessFileW函数
 25  *
 26  *      5 关闭句柄;
 27  *              RARCloseArchive函数
 28  */
 29
 30 #include <cstdio>
 31
 32 #define _UNIX
 33
 34 #include <string.h>
 35 #include <iostream>
 36
 37 #include "dll.hpp"
 38
 39 using namespace std;
 40
 41 typedef int function(unsigned int msg, long int UserData, long int P1,
 42         long int P2);
 43
 44 int main() {
 45
 46     cout<<"请输入解压模式:"<<endl;
 47     cout<<"读取文件头不解压,输入:1"<<endl;
 48     cout<<"解压文件,输入:2"<<endl;
 49
 50     long Mode;
 51     cin>>Mode;
 52
 53     // 打开压缩包
 54     RAROpenArchiveData ArchiveData;
 55     memset(&ArchiveData, 0, sizeof(RAROpenArchiveData));
 56     char name[] = "./testRar/test.rar";
 57     ArchiveData.ArcName = name;
 58
 59     // 打开模式:RAR_OM_LIST或RAR_OM_EXTRACT
 60     //        RAR_OM_LIST 只读取文件头,获取一些文件信息,而不解压文件
 61     //        RAR_OM_EXTRACT 为检测或者解压缩而打开压缩包
 62     if (Mode == 1) {
 63         ArchiveData.OpenMode = RAR_OM_LIST;
 64     } else if (Mode == 2){
 65         ArchiveData.OpenMode = RAR_OM_EXTRACT;
 66     }
 67
 68     // 输出结果:
 69     //        0成功
 70     //        ERAR_NO_MEMORY 内存不足,无法初始化数据结构
 71     //        ERAR_BAD_DATA 压缩包头损坏
 72     //        ERAR_BAD_ARCHIVE 不是有效的Rar压缩包
 73     //         ERAR_UNKNOWN_FORMAT 无法识别的压缩方式
 74     //        ERAR_EOPEN 压缩包打开错误
 75     ArchiveData.OpenResult = 0;
 76     //        设置存放注释缓冲区,最大不能超过64KB;设为null表示不读取注释
 77     ArchiveData.CmtBuf = NULL;
 78     //        设置缓冲区大小
 79     ArchiveData.CmtBufSize = 0;
 80     //        实际读取到的注释大小
 81     ArchiveData.CmtSize = 0;
 82     //        输出注释状态:
 83     //        0 注释不存在
 84     //        1  注释读取完毕
 85     //         ERAR_NO_MEMORY 内存不足
 86     //         ERAR_BAD_DATA 注释损坏
 87     //        ERAR_UNKNOWN_FORMAT 注释格式无效
 88     //        ERAR_SMALL_BUF 缓冲区过小
 89     ArchiveData.CmtState = 0;
 90
 91     HANDLE handle = RAROpenArchive(&ArchiveData);
 92     if (ArchiveData.OpenResult != 0) {
 93         cout << "解压出错" << endl;
 94         return -1;
 95     }
 96
 97     // 设置回调函数
 98     RARSetCallback(handle, function, Mode);
 99
100
101     RARHeaderData headerdata;
102     int RHCode;
103     while ((RHCode = RARReadHeader(handle, &headerdata)) == 0) {
104
105         if (Mode == 1) {
106             cout << "解压:" << headerdata.FileName << endl;
107
108             // 第一个参数:句柄
109             // 第二个参数:路转方式
110             // 第三个参数:文件解压路径不带文件名,NULL表示当前路径;这个参数只有在DestName为NULL时才有效
111             // 第四个参数:文件解压路径带文件名,当第三个参数和第个参数同时设置时,以第四个参数为准
112             int PFCode = RARProcessFile(handle, RAR_EXTRACT, NULL, NULL);
113             if (PFCode != 0) {
114                 cout << "解压出错" << endl;
115                 break;
116             }
117         }
118
119         if (Mode == 2) {
120             cout << "测试:" << headerdata.FileName << endl;
121             int PFCode = RARProcessFile(handle, RAR_TEST, NULL, NULL);
122             if (PFCode != 0) {
123                 cout << "解压出错" << endl;
124                 break;
125             }
126         }
127     }
128
129     if (RHCode == ERAR_BAD_DATA) {
130         cout << "File Header broken" << endl;
131     }
132
133     RARCloseArchive(handle);
134
135     return 0;
136
137 }
138
139 // 回调函数
140 int function(unsigned int msg, long int UserData, long int P1, long int P2) {
141
142     switch (msg) {
143
144     // 表示解压多个卷的压缩包
145     case UCM_CHANGEVOLUME: {
146
147         // 如果P2为RAR_VOL_ASK,则表示需要的一个卷找不到,例如几个分卷不在同一文件夹下
148         // 需要的卷名称为P1指向的字符串。
149         // 此时有两种解决办法,一种是把需要的卷路径(带卷名称)赋值给P1,然后返回一个非负数,解压继续
150         // 另一种办法就是直接返回-1,终止解压过程
151         if (P2 == RAR_VOL_ASK) {
152             cout << "\n\nVolume " << (char*) P1 << "is required\n"
153                     << "Possible options:\n" << endl;
154             cout << "\nEnter - try again" << endl;
155             cout << "‘R‘  -specify a new volume name" << endl;
156             cout << "‘Q‘  -quit" << endl;
157             cout << "Enter your choice:" << endl;
158
159             switch (getchar()) {
160             case ‘Q‘:
161                 return -1;
162             case ‘R‘: {
163                 cin >> (char*) P1;
164                 return 0;
165             }
166             default:
167                 return 0;
168             }
169             return 0;
170         }
171
172         // 如果P2为RAR_VOL_NOTIFY则表示,需要的卷找到了,正常打开了,P1指向的就是另一个卷的名称,此时不能修改P1的值
173         //    此时也有两种操作:
174         //    一种是直接返回非负数,继续解压过程
175         //    另一种是返回-1,终止解压过程
176         if (P2 == RAR_VOL_NOTIFY) {
177             cout << "\n... volume\n" << (char*) P1 << endl;
178             return 0;
179         }
180         return 0;
181     }
182
183         // 正常的解压过程
184         // P1指向解压数据的地址
185         // P2解压数据的大小
186     case UCM_PROCESSDATA: {
187         return 0;
188     }
189
190         // 需要密码才能解压
191         // P1指向密码缓冲区地址
192         // P2缓冲区大小
193     case UCM_NEEDPASSWORD: {
194         cin >> (char*) P1;
195         P2 = strlen((char*) P1);
196         return 0;
197     }
198     }
199 }
时间: 2024-11-06 12:44:08

unrar.dll 使用实例的相关文章

vc之dll编程实例

转载请注明作者:小刘 DLL编程实例 一. 未进行Dll封装的信号平坦区检测函数. #include<iostream> #include<vector> using namespace std; int SignalJudge(double *Signal,int nSize, double HighLow,int FlatMax); int main() { double Signal[110]={1,1,1,5,5,5,5,1,1,1,5, 5,5,5,5,1,1,1,1,1

LIB和DLL的区别与使用(转载)

转载自:http://www.cppblog.com/amazon/archive/2009/09/04/95318.html 共有两种库:一种是LIB包含了函数所在的DLL文件和文件中函数位置的信息(入口),代码由运行时加载在进程空间中的DLL提供,称为动态链接库dynamic link library.一种是LIB包含函数代码本身,在编译时直接将代码加入程序当中,称为静态链接库static link library.共有两种链接方式:动态链接使用动态链接库,允许可执行模块(.dll文件或.e

HOOK API (一)——HOOK基础+一个鼠标钩子实例

HOOK API (一)——HOOK基础+一个鼠标钩子实例 0x00 起因 最近在做毕业设计,有一个功能是需要实现对剪切板的监控和进程的防终止保护.原本想从内核层实现,但没有头绪.最后决定从调用层入手,即采用HOOK API的技术来挂钩相应的API,从而实现预期的功能.在这样的需求下,就开始学习了HOOK API. 0x01什么是HOOK API HOOK(钩子,挂钩)是一种实现Windows平台下类似于中断的机制[24].HOOK机制允许应用程序拦截并处理Windows消息或指定事件,当指定的

动态载入DLL

unit MainForm; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TDLLDemo = function(x, y: Integer): Integer; stdcall; TForm1 = class(TForm) Edit1: TEdit; Edit2: TEdit; Button1: TButton;

(转)Memcached 之 .NET(C#)实例分析

一:Memcached的安装 step1. 下载memcache(http://jehiah.cz/projects/memcached-win32)的windows稳定版(这里我下载了memcached 1.2.1 for Win32 binaries (Dec 23, 2006) 这个版本),解压放某个盘下面,比如在c:\memcachedstep2. 在终端(也即cmd命令界面)下输入 'c:\memcached\memcached.exe -d install' 安装step3. 再输入

LIB 和 DLL的区别(转载)

转自:LIB和DLL的区别与使用 共有两种库: 一种是LIB包含了函数所在的DLL文件和文件中函数位置的信息(入口),代码由运行时加载在进程空间中的DLL提供,称为动态链接库dynamic link library.一种是LIB包含函数代码本身,在编译时直接将代码加入程序当中,称为静态链接库static link library. 共有两种链接方式:动态链接使用动态链接库,允许可执行模块(.dll文件或.exe文件)仅包含在运行时定位DLL函数的可执行代码所需的信息.静态链接使用静态链接库,链接

c++/c语言中如何调用DLL

参考网站如下: ?http://blog.csdn.net/yusongwhu/article/details/7577461 http://www.cnblogs.com/lhbssc/archive/2012/02/08/2342853.html 具体内容如下: (1)篇? 今天在研究怎么在vc中调用动态dll的问题,看了一个下午,总算有些眉目. 首先来说说调用的原理: 调用DLL,首先需要将DLL文件映像到用户进程的地址空间中,然后才能进行函数调用,这个函数和进程内部一般函数的调用方法相同

DLL入门浅析【转】

 1.建立DLL动态库 动态链接库(DLL)是从C语言函数库和Pascal库单元的概念发展而来的.所有的C语言标准库函数都存放在某一函数库中.在链接应用程序的过程中,链接器从库文件中拷贝程序调用的函数代码,并把这些函数代码添加到可执行文件中.这种方法同只把函数储存在已编译的OBJ文件中相比更有利于代码的重用.但随着Windows这样的多任务环境的出现,函数库的方法显得过于累赘.如果为了完成屏幕输出.消息处理.内存管理.对话框等操作,每个程序都不得不拥有自己的函数,那么Windows程序将变得非常

DLL的出入口函数

DLL_PROCESS_ATTACH       进程启动或者调用LoadLibrary 时候,DLL映射到当前进程的地址空间,这个事件期间,DLL初始化实例数据DLL_PROCESS_DETACH        DLL正从进程的地址空间分离出来,这也许是进程本身退出或者调用了FreeLibrary,在该事件里,DLL也许没有初始化任何实例.DLL_THREAD_ATTACH         进程创建了一个新的线程.这时,系统会调用所有和这个进程相关联的DLL入口函数.这个调用在新线程的环境中进