PE-INFO

PEInfo:(目标)
(1).独立开发PE分析和修改工具, 并将包含代码的节内容反汇编显示出来.

http://www.anqn.com/jiamijiemi/gongjujiqiao/2008-11-04/a09103385.shtml
(2).运用进程调试知识, 显示目标程序所运行的指令序列.

 

(1):

pe分析
#include <windos.h>
int main(int argc ,char* argv[])
     {
        if (argc<2)return 1;
        char* pFileName=argv[1];
            if(pFileName)
               { FILE * filept=fopen(pFileName,"r");
                  IMAGE_DOS_HEADER dosHdr;
                  IMAGE_NT_HEADER    ntHdr;
                  if(filept)
                    { fread(&dosHdr,sizeof(IMAGE_DOS_HEADER,1,filept);//read dos header
                       fseek(fliept,dosHdr.e_lfanew,SEEK_SET);  //seek to nt header
                       fread(&ntHdr,sizeof(IMAGE_NT_HEADER,1,filept); //read from nt header
                       if ((dosHdr.e_magic==IMAGE_DOS_SIGNATURE)&&(ntHdr.sinature==IMAGE_NT_SIGNATURE ))
   //two of pe fields should be.
                           printf("%s is PE /n",pFileName);
                      else
                           printf("%s is not PE /n",pFileName);
                    }
                 else
                 printf("open  %s error ./n",pFileName);
              }              
     return 0;
     }

 (2)

PE修改

a.使用pe_editor工具来通过添加新节来修改pe文件。

b. c++编程实现修改pe文件

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现PE文件解析器的步骤如下: 1. 读取PE文件头,获取文件头信息。 2. 读取节表头,获取节表信息。 3. 读取导入表、导出表、重定位表等其他表,获取相关信息。 4. 解析每个节的数据,获取代码、数据等信息。 5. 根据节表中的信息,将PE文件中的代码、数据等部分映射到内存中。 6. 解析导入表,获取导入的函数信息,并进行符号解析。 7. 解析导出表,获取导出函数信息,并生成符号表。 8. 处理重定位表,修正代码中的地址。 9. 实现其他功能,如获取PE文件中的资源信息、版本信息等。 下面是一个简单的golang实现PE文件解析器的代码示例: ```go package main import ( "debug/pe" "fmt" "os" ) func main() { if len(os.Args) != 2 { fmt.Println("Usage: pe-parser <filename>") return } file, err := os.Open(os.Args[1]) if err != nil { fmt.Println("Failed to open file:", err) return } defer file.Close() peFile, err := pe.NewFile(file) if err != nil { fmt.Println("Failed to parse PE file:", err) return } fmt.Println("PE Header Info:") fmt.Printf("\tMachine: %s\n", peFile.FileHeader.Machine) fmt.Printf("\tNumber of Sections: %d\n", peFile.FileHeader.NumberOfSections) fmt.Printf("\tSize of Optional Header: %d\n", peFile.FileHeader.SizeOfOptionalHeader) fmt.Println("\nSection Table Info:") for _, section := range peFile.Sections { fmt.Printf("\tName: %s\n", section.Name) fmt.Printf("\tVirtual Address: %d\n", section.VirtualAddress) fmt.Printf("\tVirtual Size: %d\n", section.VirtualSize) fmt.Printf("\tRaw Size: %d\n", section.Size) fmt.Printf("\tOffset: %d\n", section.Offset) fmt.Println() } } ``` 该代码使用了golang标准库中的`debug/pe`包来实现PE文件解析器,可以获取PE文件头信息和节表信息。你可以根据需要扩展代码以支持更多功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值