C/C++信息隐写术(四)之大程序藏入BMP文件
在閱讀這篇文章時請先閱讀第三篇,第三篇鏈接如下:
http://blog.csdn.net/qq78442761/article/details/54893792
這一節里面我們要做的是 把一個exe程序放入bmp文件中。但不放入alpha通道,而是對文件進行擴大,但不影響圖片瀏覽器打開。
而,這個exe程序的作用是從百度云上下載一張圖片:
相關文章在此鏈接http://blog.csdn.net/qq78442761/article/details/54605217
下面是這個exe的代碼:
#include <Windows.h> #include <stdio.h> #include <direct.h> #pragma comment(lib,"URlmon") int main() {char buffer[MAX_PATH];_getcwd(buffer, MAX_PATH);strcat_s(buffer, "//1.jpg");HRESULT Result = URLDownloadToFileA(NULL, "http://shcm09.baidupcs.com/file/de0243d60205717a2a74aea53c0c500c?bkt=p3-1400de0243d60205717a2a74aea53c0c500cb056e2ab00000000b511&fid=2555278822-250528-705479749498397&time=1486386954&sign=FDTAXGERLBH-DCb740ccc5511e5e8fedcff06b081203-dMTIm7f6FISsqD5yejddiOMciJ0%3D&to=sh09vb&fm=Yan,B,M,mn&sta_dx=46353&sta_cs=1&sta_ft=jpg&sta_ct=4&sta_mt=4&fm2=Yangquan,B,M,mn&newver=1&newfm=1&secfm=1&flow_ver=3&pkey=1400de0243d60205717a2a74aea53c0c500cb056e2ab00000000b511&sl=76480590&expires=8h&rt=sh&r=807535541&mlogid=855491576450374303&vuk=2555278822&vbdid=1170054185&fin=1.jpg&fn=1.jpg&slt=pm&uta=0&rtype=1&iv=0&isw=0&dp-logid=855491576450374303&dp-callid=0.1.1&csl=80&csign=1QjHmPbR1MqUYVwmwISHS%2FlW2A0%3D", buffer, 0, NULL);switch (Result){case S_OK:printf("The download started successfully.\n"); break;case E_OUTOFMEMORY: printf("The buffer length is invalid, or there is insufficient memory to complete the operation.\n"); break;}system("pause");return 0; }下面是運行結果:
現在我們把這個程序的release模式中運行庫設置為MT,如下圖所示:
隨后我們生成release版的文件(如下圖所示):
這時我們把他拷貝進HideFileDemo這個工程里面(如下圖所示):
要隱藏的文件做好了 ,下面要做的是對BMP進行修改。
在打代碼前,我們先說下原理:
打開這個BMP文件后 我們可以看到一個叫size的變量(如下圖所示):
?
我們可以看到一個bfSize,圖片查看器并不會自己把一個文件的大小讀取出去,而是直接讀取這個參數,
所以我們可以做一件事情,就是對這個圖片的大小進行擴大,但不改變這個bfSize的值。
如下圖所示:
我們發現他本身的大小和那個結構體不一樣。我們保存后,看看圖片會不會正常顯示。
我們發現,這并沒有什么影響,所以。我們的思路就是寫一個程序,這個程序把要插入的程序讀取成二進制模式,然后插入到這個bmp文件的最后。
下面是關鍵代碼:(待會會提供源碼下載地址)
void CBMPHide::saveExeFile(char* FileName) {this->sExEFileName = FileName;if (pExEBuf) //如果已經生成就釋放掉{delete[]pExEBuf;}HANDLE hfile = CreateFileA(FileName, GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, 0, 0);if (hfile == INVALID_HANDLE_VALUE){return;}dwExESize = GetFileSize(hfile, 0); //獲取文件的大小pExEBuf = new byte[dwExESize];DWORD dwRead = 0;ReadFile(hfile, pExEBuf, dwExESize, &dwRead, 0);if (dwRead != dwExESize){delete[]pExEBuf;pExEBuf = 0;return;}CloseHandle(hfile);LPBYTE pEnd = pBuf+dwBmpSize;int nHide; //成功隱藏的字節數for (nHide = 0; nHide < dwExESize; nHide++, pEnd++){*pEnd = pExEBuf[nHide]; //寫入一個字節}this->save();}void CBMPHide::showExeFile(char* szBmpFIleName /*= NULL*/) {string sDstFileName = "";if (szBmpFIleName == 0){sDstFileName = sBmpFileName + ".hide.bmp";}elsesDstFileName = szBmpFIleName;HANDLE hfile = CreateFileA(sDstFileName.c_str(),GENERIC_READ | GENERIC_WRITE,FILE_SHARE_READ | FILE_SHARE_WRITE,NULL,OPEN_EXISTING, 0, 0);if (hfile == INVALID_HANDLE_VALUE){return;}DWORD dwSize = GetFileSize(hfile, 0);LPBYTE pBuf1 = new byte[dwSize];DWORD dwRead = 0;ReadFile(hfile, pBuf1, dwSize, &dwRead, 0);CloseHandle(hfile);//文件內容讀取到pBuf1中LPBYTE pStr = pBuf1 + m_fileHdr->bfSize;char szTmp[1024*1000];RtlZeroMemory(szTmp, 1024 * 1000);for (int i = 0; i < dwExESize; i++){szTmp[i] = *pStr;pStr += 1;}string sDstFileName2 = sBmpFileName + ".hide.exe";HANDLE hfile1 = CreateFileA(sDstFileName2.c_str(),GENERIC_READ | GENERIC_WRITE,FILE_SHARE_READ | FILE_SHARE_WRITE,NULL,CREATE_ALWAYS, 0, 0);if (hfile1 == INVALID_HANDLE_VALUE){return;}DWORD dwWritten = 0;WriteFile(hfile, szTmp, dwExESize, &dwWritten, 0);if (dwBmpSize != dwWritten){return;}CloseHandle(hfile1);delete[]pBuf1; }下面是源碼下載地址:
http://download.csdn.net/detail/qq78442761/9748468
下面是運行結果:
在此,本套C/C++信息隱寫術暫時結束了,謝謝大家捧場。
總結
以上是生活随笔為你收集整理的C/C++信息隐写术(四)之大程序藏入BMP文件的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 多路查找树之2-3树(理论)
- 下一篇: 汇编基础(一)