分享
 
 
 

如何编写一个文件捆绑工具

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

在2002年刚学VC的时候写过文件捆绑工具,当时是配合自己写的一个QQ木马使用。后来去年在某个论坛上有人问起了文件捆绑的事,我就翻出以前的程序,写下了这篇文档,今天整理硬盘的时候,把这文章发了上来,其实很简单。

文件捆绑可以用在很多地方,比如木马。也可以在发行软件的时候把DLL捆绑在EXE文件后面,然后在EXE执行的时候动态调用DLL等等。。

编译环境:WIN2K+VC6。

先假设我们要把 test1.exe和test2.exe这两个文件捆绑成target.exe这一个文件,然后在运行target.exe的时候实现同时运行test1.exe和test2.exe。

提一个小常识,PE格式的文件只要不修改文件头和文件中间的内容,而只是在文件末尾添加数据,那么这个PE文件可以正常执行。你可以试一

试在命令行方式下执行copy test1.exe+test2.exe,命令执行完成后,test2.exe被添加到test1.exe文件尾,执行合并后的test1.exe虽然正常,但是test2.exe得不

到执行。OK,这就是我们今天要解决的问题。我的想法是这样的。把三个文件捆绑在一起,捆绑后target.exe实际包含三个文件,其中aaa.exe是我们自己写的程序,test1.exe和test2.exe是我们要捆绑的程序。

结构如下

---------------------------------------

|aaa.exe|test1.exe|test2.exe|

---------------------------------------

整个文件就叫target.exe,如果结构如上所示,那么我们执行target.exe的时候实际上只有aaa.exe才会得到执行,这里的aaa.exe是我们自己写的,我们就让aaa.exe多做点事,他要做的事就是:1、把test2.exe读出来另存为c:\test2.exe,把test1.exe的内容读出来另存为c:\test1.exe。2、调用CreateProcess来创建两个新进程运行test1.exe和test2.exe。3、调用ExitProcess结束自身的进程。

这样一来我们的目的就达到了。同时为了隐蔽起见,我们可以把aaa.exe的窗口界面不显示出来。

但是又有一个问题,读取的时候怎样才能分辨出哪一段数据是test1.exe,哪一段数据是test2.exe?那我们就再想办法把上面的结构再扩充一下。

-----------------------------------------------------

|aaa.exe|test1.exe|test2.exe|len2|len1|

-----------------------------------------------------

在文件最后面再加两段数据,分别用来存放test1.exe的文件长度和test2.exe的文件长度。并且固定len2和len1为30字节的长度。这样在aaa.exe得到执行的时候先后面的两个30字节内容,内容就是两个文件的长度,再根据这两个长度就可以准确读取到test1.exe和test1.exe的内容。

看看aaa.exe程序的关键代码:

CFile fSource(_pgmptr,CFile::modeRead | CFile::modeNoTruncate); //得到target.exe的文件长度

int iSourceLength = fSource.GetLength();

fSource.Seek(iSourceLength-60,CFile::begin);//移动文件指针到第test2.exe文件的末尾

char buffer[40];

ZeroMemory(buffer,40);

fSource.Read(buffer,30);//读取第len2的内容,也就是test2.exe的长度

int iTargetLength = atoi(buffer);

fSource.Seek(iSourceLength-iTargetLength-60,CFile::begin);//移动文件指针到test2.exe文件的开头

CFile fTarget("c:\\test2.exe",CFile::modeCreate | CFile::modeWrite |

CFile::modeNoTruncate);//创建一个新文件为c:\\test2.exe

char *pBuffer = new char[iTargetLength];//分配缓冲区

ZeroMemory(pBuffer,iTargetLength);

fSource.Read(pBuffer,iTargetLength);//将第test2.exe文件读到缓冲区

fTarget.Write(pBuffer,iTargetLength);//将缓冲区内容写入c:\test2.exe

delete []pBuffer;

好了,现在test2.exe文件已经读出来了,接下来就是要读test1.exe的内容,过程大同小异

fSource.Seek(iSourceLength-30,CFile::begin);//将文件指针移动到len1的开头

ZeroMemory(buffer,40);

fSource.Read(buffer,30);//读取len1的内容,len1的内容是test1.exe文件的长度

int filelen = atoi(buffer);

fSource.Seek(iSourceLength-60-filelen-iTargetLength,CFile::begin);//将文件指针移动到test1.exe文件头

fTarget.Open("c:\\test2.exe",CFile::modeCreate | CFile::modeWrite | CFile::modeNoTruncate);

pBuffer = new char[filelen];

ZeroMemory(pBuffer,filelen);

fSource.Read(pBuffer,filelen);//将test1.exe文件读到缓冲区

fTarget.Write(pBuffer,filelen);//将test1.exe文件写入c:\test1.exe

delete []pBuffer;

fSource.Close();

fTarget.Close();

现在我们就用CreateProcess来运行创建两个新进程就可以运行c:\test1.exe和c:\test2.exe了。创建新进程的代码很简单我就不写了。

这部分是写完了,但是我们捆绑文件的部分还没写完,重新新建一个基于对话框的程序。

CFile fSource("c:\\aaa.exe",CFile::modeReadWrite | CFile::modeNoTruncate); //就是上面我们写的aaa.exe

fSource.SeekToEnd();//移动文件指针到文件尾

CFile fFirstFile(m_FirstFile,CFile::modeRead | CFile::modeNoTruncate); //这段代码是把test1.exe添加到aaa.exe尾部

int ilen = fFirstFile.GetLength();

int len = ilen;

char *pBuffer = new char[ilen];

ZeroMemory(pBuffer,ilen);

fFirstFile.Read(pBuffer,ilen);

fSource.Write(pBuffer,ilen);

fFirstFile.Close();

delete pBuffer;

CFile fSecondFile(m_SecondFile,CFile::modeRead | CFile::modeNoTruncate); //这段代码是捆绑test2.exe的

ilen = fSecondFile.GetLength();

pBuffer = new char[ilen];

ZeroMemory(pBuffer,ilen);

fSecondFile.Read(pBuffer,ilen);

fSource.Write(pBuffer,ilen);

fSecondFile.Close();

delete pBuffer;

char tempbuffer[30];//将test2.exe的长度转换成字符串,如果长度不够30就添加空格至30,再添加到文件尾部

ZeroMemory(tempbuffer,30);

itoa(ilen,tempbuffer,10);

while (strlen(tempbuffer) < 30)

{

strcat(tempbuffer," ");

}

fSource.Write(tempbuffer,30);

ZeroMemory(tempbuffer,30);//将test2.exe的长度转换成字符串,如果长度不够30就添加空格至30,再添加到文件尾部

itoa(len,tempbuffer,10);

while (strlen(tempbuffer) < 30)

{

strcat(tempbuffer," ");

}

fSource.Write(tempbuffer,30);

fSource.Close();

::MessageBox(NULL,"捆绑完成","提示",MB_ICONINFORMATION);

OK,这样我们就生成了一个新文件target.exe,这个target.exe的结构上面已经说了。执行target.exe后,aaa.exe首先得到执行,然后test1.exe和test2.exe都会执行。为了增强隐蔽性,我们在aaa.exe的OnInitDialog()函数里写下如下代码:

ModifyStyleEx(WS_EX_APPWINDOW, WS_EX_TOOLWINDOW);

::MoveWindow(m_hWnd,0,0,0,0,TRUE);

这样aaa.exe执行的时候没窗口,也不会在任务栏上显示任务条。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有