加载exe的PE信息并输出相关PE信息的一段c++代码

简介:
今天看了下关于windows平台的PE结构,然后通过C++写了一个简单的加载PE信息的程序,只加载了DOS头、NT头、以及节点的信息,以后补上关于加载输出表、输入表的相关代码,详细代码如下:
#include <iostream> 
#include < string
#include <Windows.h> 
 
using  namespace std; 
 
//Dos Header 
 
typedef  struct _BEGIN09_IMAGE_DOS_HEADER {  // DOS .EXE header 
 
        WORD e_magic;  // Magic number 
 
        WORD e_cblp;  // Bytes on last page of file 
 
        WORD e_cp;  // Pages in file 
 
        WORD e_crlc;  // Relocations 
 
        WORD e_cparhdr;  // Size of header in paragraphs 
 
        WORD e_minalloc;  // Minimum extra paragraphs needed 
 
        WORD e_maxalloc;  // Maximum extra paragraphs needed 
 
        WORD e_ss;  // Initial (relative) SS value 
 
        WORD e_sp;  // Initial SP value 
 
        WORD e_csum;  // Checksum 
 
        WORD e_ip;  // Initial IP value 
 
        WORD e_cs;  // Initial (relative) CS value 
 
        WORD e_lfarlc;  // File address of relocation table 
 
        WORD e_ovno;  // Overlay number 
 
        WORD e_res[4];  // Reserved words 
 
        WORD e_oemid;  // OEM identifier (for e_oeminfo) 
 
        WORD e_oeminfo;  // OEM information; e_oemid specific 
 
        WORD e_res2[10];  // Reserved words 
 
        LONG e_lfanew;  // File address of new exe header 
 
} BEGIN09_IMAGE_DOS_HEADER, *PBEGIN09_IMAGE_DOS_HEADER; 
 
//NT_Header 
 
typedef  struct _BEGIN09_IMAGE_NT_HEADERS { 
        DWORD Signature; 
        IMAGE_FILE_HEADER FileHeader; 
        IMAGE_OPTIONAL_HEADER32 OptionalHeader; 
} BEGIN09_IMAGE_NT_HEADERS32, *PBEGIN09_IMAGE_NT_HEADERS32; 
 
//File Header 
 
typedef  struct _BEGIN09_IMAGE_FILE_HEADER { 
        WORD Machine; 
        WORD NumberOfSections; 
        DWORD TimeDateStamp; 
        DWORD PointerToSymbolTable; 
        DWORD NumberOfSymbols; 
        WORD SizeOfOptionalHeader; 
        WORD Characteristics; 
} BEGIN09_IMAGE_FILE_HEADER, *PBEGIN09_IMAGE_FILE_HEADER; 
 
//Option Header 
 
typedef  struct _BEGIN09_IMAGE_OPTIONAL_HEADER { 
         // 
 
         // Standard fields. 
 
         // 
 
 
        WORD Magic; 
        BYTE MajorLinkerVersion; 
        BYTE MinorLinkerVersion; 
        DWORD SizeOfCode; 
        DWORD SizeOfInitializedData; 
        DWORD SizeOfUninitializedData; 
        DWORD AddressOfEntryPoint; 
        DWORD BaseOfCode; 
        DWORD BaseOfData; 
 
         // 
 
         // NT additional fields. 
 
         // 
 
 
        DWORD ImageBase; 
        DWORD SectionAlignment; 
        DWORD FileAlignment; 
        WORD MajorOperatingSystemVersion; 
        WORD MinorOperatingSystemVersion; 
        WORD MajorImageVersion; 
        WORD MinorImageVersion; 
        WORD MajorSubsystemVersion; 
        WORD MinorSubsystemVersion; 
        DWORD Win32VersionValue; 
        DWORD SizeOfImage; 
        DWORD SizeOfHeaders; 
        DWORD CheckSum; 
        WORD Subsystem; 
        WORD DllCharacteristics; 
        DWORD SizeOfStackReserve; 
        DWORD SizeOfStackCommit; 
        DWORD SizeOfHeapReserve; 
        DWORD SizeOfHeapCommit; 
        DWORD LoaderFlags; 
        DWORD NumberOfRvaAndSizes; 
        IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES]; 
} BEGIN09_IMAGE_OPTIONAL_HEADER32, *PBEGIN09_IMAGE_OPTIONAL_HEADER32; 
 
//Data Dir 
 
typedef  struct _BEGIN09_IMAGE_DATA_DIRECTORY { 
        DWORD VirtualAddress; 
        DWORD Size; 
} BEGIN09_IMAGE_DATA_DIRECTORY, *PBEGIN09_IMAGE_DATA_DIRECTORY; 
 
//Sec Header 
 
typedef  struct _BEGIN09_IMAGE_SECTION_HEADER { 
        BYTE Name[IMAGE_SIZEOF_SHORT_NAME]; 
        union { 
                DWORD PhysicalAddress; 
                DWORD VirtualSize; 
        } Misc; 
        DWORD VirtualAddress; 
        DWORD SizeOfRawData; 
        DWORD PointerToRawData; 
        DWORD PointerToRelocations; 
        DWORD PointerToLinenumbers; 
        WORD NumberOfRelocations; 
        WORD NumberOfLinenumbers; 
        DWORD Characteristics; 
} BEGIN09_IMAGE_SECTION_HEADER, *PBEGIN09_IMAGE_SECTION_HEADER; 
 
int main() 

         
        BEGIN09_IMAGE_DOS_HEADER                        *pDos_Header = NULL; 
        BEGIN09_IMAGE_NT_HEADERS32                        *pNt_Header = NULL; 
        BEGIN09_IMAGE_SECTION_HEADER                *pSection_Header = NULL; 
         int                                                                        nFileSize = 0x400; 
         int                                                                        nRetCode = 0; 
        BYTE                                                         *pByteBuffer = NULL; 
        size_t nReadBytes = 0; 
         
         
        FILE *pFileOpen = fopen(  "C:\\Documents and Settings\\Administrator\\桌面\\PE\\PE\\ASM.exe" ,  "r+b" ); 
         if ( NULL == pFileOpen ) 
        { 
                 goto Exit0; 
        } 
         
         pByteBuffer =  new BYTE[ nFileSize + 1 ]; 
          if ( NULL == pByteBuffer ) 
         { 
                  goto Exit0; 
         } 
 
         memset( pByteBuffer, 0, nFileSize + 1); 
                    
         nReadBytes = fread( pByteBuffer,  sizeof(BYTE), nFileSize, pFileOpen); 
          if ( nReadBytes == 0 ) 
         { 
                  goto Exit0; 
        } 
    
         pDos_Header = (BEGIN09_IMAGE_DOS_HEADER*) (pByteBuffer); 
          if ( NULL == pDos_Header ) 
         { 
                  goto Exit0; 
         } 
    
         pNt_Header = ( BEGIN09_IMAGE_NT_HEADERS32* ) ( pByteBuffer + pDos_Header->e_lfanew ); 
          if ( NULL == pNt_Header ) 
         { 
                  goto Exit0; 
         } 
            
         pSection_Header = ( BEGIN09_IMAGE_SECTION_HEADER* ) ( pByteBuffer + pDos_Header->e_lfanew +  sizeof(DWORD) +  sizeof(BEGIN09_IMAGE_FILE_HEADER) + pNt_Header->FileHeader.SizeOfOptionalHeader ); 
          if ( NULL == pSection_Header) 
         { 
                  goto Exit0; 
         } 
 
         nRetCode = 1; 
         
        cout<< "此程序的运行平台为:"<<endl; 
          if ( 0x014C == pNt_Header->FileHeader.Machine ) 
         { 
                 cout<< "运行平台为 Intel 386"<<endl; 
         } 
          else 
         { 
                 cout<< "未知的运行平台"<<endl; 
         } 
    
         cout<< "此文件程序入口为:"<<endl; 
         cout<<pNt_Header->OptionalHeader.AddressOfEntryPoint; 
         cout<< "此程序一共有多少个节:"<<endl; 
         cout<<pNt_Header->FileHeader.NumberOfSections<<endl; 
         cout<< "此程序的基地址为:"<<endl; 
         cout<<pNt_Header->OptionalHeader.ImageBase<<endl; 
 
Exit0: 
         return nRetCode; 
}
 
此程序用了静态的文件路径以及文件记载信息的大小申请空间都是用的固定的数值,比较山寨,呵呵以后写一个详细的加载PE信息的程序.



本文转自wiliiwin 51CTO博客,原文链接:http://blog.51cto.com/wiliiwin/236425
相关文章
|
C++
C++ 语言异常处理实战:在编程潮流中坚守稳定,开启代码可靠之旅
【8月更文挑战第22天】C++的异常处理机制是确保程序稳定的关键特性。它允许程序在遇到错误时优雅地响应而非直接崩溃。通过`throw`抛出异常,并用`catch`捕获处理,可使程序控制流跳转至错误处理代码。例如,在进行除法运算或文件读取时,若发生除数为零或文件无法打开等错误,则可通过抛出异常并在调用处捕获来妥善处理这些情况。恰当使用异常处理能显著提升程序的健壮性和维护性。
354 2
|
8月前
|
C++ Windows
应用程序无法正常启动(0xc0000005)?C++报错0xC0000005如何解决?使命召唤17频频出现闪退,错误代码0xC0000005(0x0)
简介: 本文介绍了Windows应用程序出现错误代码0xc0000005的解决方法,该错误多由C++运行库配置不一致或内存访问越界引起。提供包括统一运行库配置、调试排查及安装Visual C++运行库等解决方案,并附有修复工具下载链接。
2211 1
|
存储 安全 C语言
C++ String揭秘:写高效代码的关键
在C++编程中,字符串操作是不可避免的一部分。从简单的字符串拼接到复杂的文本处理,C++的string类为开发者提供了一种更高效、灵活且安全的方式来管理和操作字符串。本文将从基础操作入手,逐步揭开C++ string类的奥秘,帮助你深入理解其内部机制,并学会如何在实际开发中充分发挥其性能和优势。
|
10月前
|
API 数据安全/隐私保护 C++
永久修改机器码工具, exe一机一码破解工具,软件机器码一键修改工具【c++代码】
程序实现了完整的机器码修改功能,包含进程查找、内存扫描、模式匹配和修改操作。代码使用
|
算法框架/工具 C++ Python
根据相机旋转矩阵求解三个轴的旋转角/欧拉角/姿态角 或 旋转矩阵与欧拉角(Euler Angles)之间的相互转换,以及python和C++代码实现
根据相机旋转矩阵求解三个轴的旋转角/欧拉角/姿态角 或 旋转矩阵与欧拉角(Euler Angles)之间的相互转换,以及python和C++代码实现
1657 0
|
11月前
|
C++
爱心代码 C++
这段C++代码使用EasyX图形库生成动态爱心图案。程序通过数学公式绘制爱心形状,并以帧动画形式呈现渐变效果。运行时需安装EasyX库,教程链接:http://【EasyX图形库的安装和使用】https://www.bilibili.com/video/BV1Xv4y1p7z1。代码中定义了屏幕尺寸、颜色数组等参数,利用随机数与数学函数生成动态点位,模拟爱心扩散与收缩动画,最终实现流畅的视觉效果。
1213 0
|
算法 安全 C++
提高C/C++代码的可读性
提高C/C++代码的可读性
386 4
|
Linux C语言 C++
vsCode远程执行c和c++代码并操控linux服务器完整教程
这篇文章提供了一个完整的教程,介绍如何在Visual Studio Code中配置和使用插件来远程执行C和C++代码,并操控Linux服务器,包括安装VSCode、安装插件、配置插件、配置编译工具、升级glibc和编写代码进行调试的步骤。
4069 0
vsCode远程执行c和c++代码并操控linux服务器完整教程
2合1,整合C++类(Class)代码转换为MASM32代码的平台
2合1,整合C++类(Class)代码转换为MASM32代码的平台
|
程序员 C++ 开发者
C++命名空间揭秘:一招解决全局冲突,让你的代码模块化战斗值飙升!
【8月更文挑战第22天】在C++中,命名空间是解决命名冲突的关键机制,它帮助开发者组织代码并提升可维护性。本文通过一个图形库开发案例,展示了如何利用命名空间避免圆形和矩形类间的命名冲突。通过定义和实现这些类,并在主函数中使用命名空间创建对象及调用方法,我们不仅解决了冲突问题,还提高了代码的模块化程度和组织结构。这为实际项目开发提供了宝贵的参考经验。
309 2