1回顶部 在2002年刚学VC的时候写过文件捆绑工具,当时是配合自己写的一个QQ木马使用。后来去年在某个论坛上有人问起了文件捆绑的事,我就翻出以前的程序,写下了这篇文档,今天整理硬盘的时候,把这文章发了上来,其实很简单。 2回顶部 ----------------------------------------------------- |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的内容,过程大同小异 3回顶部 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); 4回顶部 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); 5回顶部 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执行的时候没窗口,也不会在任务栏上显示任务条。
|
正在阅读:实例编程:用VC写个文件捆绑工具实例编程:用VC写个文件捆绑工具
2004-02-24 10:14
出处:PConline
责任编辑:linjixiong