日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

Windows Pe 第三章 PE头文件-EX-相关编程-1(PE头内容获取)

發布時間:2025/6/17 windows 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Windows Pe 第三章 PE头文件-EX-相关编程-1(PE头内容获取) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

獲取pE頭相關的內容,就是類似如下內容


原理:比較簡單,直接讀取PE到內存,然后直接強轉就行了。

#include <windows.h> #include <stdio.h> #include <tchar.h>#pragma warning(disable:4996)void viewImageFileCharacteristics(WORD);int _tmain(int argc, TCHAR *argv[]) { PIMAGE_DOS_HEADER pImageDosHeader; PIMAGE_NT_HEADERS pImageNtHeaders; PIMAGE_FILE_HEADER pImageFileHeader; HANDLE hFile; HANDLE hMapObject; PUCHAR uFileMap; //if(argc<2) //return -1; if(!(hFile=CreateFile(/*argv[1]*/L"c:\\hello.exe",GENERIC_READ,0,NULL,OPEN_EXISTING,0,0))) return -1; if (!(hMapObject=CreateFileMapping(hFile,NULL,PAGE_READONLY,0,0,NULL))) return -1; if(!(uFileMap=(PUCHAR)MapViewOfFile(hMapObject,FILE_MAP_READ,0,0,0))) return -1; pImageDosHeader=(PIMAGE_DOS_HEADER)uFileMap; if (pImageDosHeader->e_magic != IMAGE_DOS_SIGNATURE) return -1; pImageNtHeaders=(PIMAGE_NT_HEADERS)((PUCHAR)uFileMap+pImageDosHeader->e_lfanew); if (pImageNtHeaders->Signature!=IMAGE_NT_SIGNATURE) return -1; pImageFileHeader=(PIMAGE_FILE_HEADER) &(pImageNtHeaders->FileHeader);printf("Machine: 0x%04X",pImageFileHeader->Machine); ((pImageFileHeader->Machine == IMAGE_FILE_MACHINE_I386) ?printf("(I386) \n") :printf(" (?) \n")); printf("NumberOfSections: 0x%04X\n",pImageFileHeader->NumberOfSections); printf("TimeDateStamp: 0x%08X\n",pImageFileHeader->TimeDateStamp); printf("PointerToSymbolTable: 0x08X\n",pImageFileHeader->PointerToSymbolTable); printf("NumberOfSymbols: 0x%08X\n",pImageFileHeader->NumberOfSymbols); printf("SizeOfOptionalHeader: 0x%04X\n",pImageFileHeader->SizeOfOptionalHeader); printf("Characteristics: 0x%04X\n",pImageFileHeader->Characteristics); viewImageFileCharacteristics(pImageFileHeader->Characteristics); UnmapViewOfFile(uFileMap); CloseHandle(hMapObject); CloseHandle(hFile); return 0; }void viewImageFileCharacteristics(WORD wCharacteristics) { char szCharacteristics[100]; memset(szCharacteristics,0,100); szCharacteristics[0]='('; if (wCharacteristics & 0x0001) strcat(szCharacteristics,"RELOCS_STRIPPED|"); if (wCharacteristics & 0x0002) strcat(szCharacteristics,"EXECUTABLE_IMAGE|"); if (wCharacteristics & 0x0004) strcat(szCharacteristics,"LINE_NUMS_STRIPPED|"); if (wCharacteristics & 0x0100) strcat(szCharacteristics,"32BIT_MACHINE|"); if (wCharacteristics & 0x0200) strcat(szCharacteristics,"DEBUG_STRIPPED|"); if (wCharacteristics & 0x1000) strcat(szCharacteristics,"FILE_SYSTEM|"); if (wCharacteristics & 0x2000) strcat(szCharacteristics,"FILE_DLL|"); szCharacteristics[strlen(szCharacteristics)-1]=')'; szCharacteristics[strlen(szCharacteristics)]='\0'; printf(" %s\n",szCharacteristics); }

執行結果:


?

總結

以上是生活随笔為你收集整理的Windows Pe 第三章 PE头文件-EX-相关编程-1(PE头内容获取)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。