热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PE总结9PE文件结构之解析导出表

本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。

// 导出表2.cpp : 定义控制台应用程序的入口点。
//#include "stdafx.h"
#include
#include
#include DWORD RVA2OffSet(DWORD dwRVA, PIMAGE_NT_HEADERS32 pNt)
{DWORD dwOffset &#61; 0;//获取区段头表PIMAGE_SECTION_HEADER pSection &#61; IMAGE_FIRST_SECTION(pNt);//获取区段的数量DWORD dwSize &#61; pNt->FileHeader.NumberOfSections;//遍历找到dwRVA所在的区段for (DWORD i &#61; 0; i &#61;pSection[i].VirtualAddress &&dwRVA <(pSection[i].Misc.VirtualSize &#43; pSection[i].VirtualAddress)){dwOffset &#61; dwRVA - pSection[i].VirtualAddress &#43; pSection[i].PointerToRawData;return dwOffset;}}return dwOffset;
}void ShowExport(PVOID lpImage, DWORD dwSize)
{//获取Dos头PIMAGE_DOS_HEADER pDos &#61; (PIMAGE_DOS_HEADER)lpImage;if (IMAGE_DOS_SIGNATURE !&#61; pDos->e_magic ){return;}//获取nt头PIMAGE_NT_HEADERS32 pNt &#61; (PIMAGE_NT_HEADERS32)((DWORD)lpImage &#43; pDos->e_lfanew);if (IMAGE_NT_SIGNATURE !&#61; pNt->Signature){return;}//获取目录表PIMAGE_DATA_DIRECTORY pData &#61; pNt->OptionalHeader.DataDirectory;//获取导出表RVApData &#61; &(pData[IMAGE_DIRECTORY_ENTRY_EXPORT]);//获取导出表在文件中的偏移DWORD dwExtOffset &#61; RVA2OffSet(pData->VirtualAddress, pNt);PIMAGE_EXPORT_DIRECTORY pExpt &#61; (PIMAGE_EXPORT_DIRECTORY)((DWORD)lpImage &#43; dwExtOffset);//获取数量DWORD dwFunCount &#61; pExpt->NumberOfFunctions;DWORD dwNameCount &#61; pExpt->NumberOfNames;DWORD dwModName &#61; pExpt->Name;//获取地址表PDWORD pEAT &#61; (PDWORD)((DWORD)lpImage &#43; RVA2OffSet(pExpt->AddressOfFunctions, pNt));//获取名称表PDWORD pENT &#61; (PDWORD)((DWORD)lpImage &#43;RVA2OffSet(pExpt->AddressOfNames, pNt));//获取索引表-----这里要使用WORDPWORD pEIT &#61; (PWORD)((DWORD)lpImage &#43; RVA2OffSet(pExpt->AddressOfNameOrdinals, pNt));for (DWORD dwOrd &#61; 0; dwOrd Base &#43; dwOrd;//获取导出函数地址值DWORD dwFunOffset &#61; RVA2OffSet(pEAT[dwOrd], pNt);printf("函数序号: %08d RVA:%p 函数偏移:%p ",dwID,pEAT[dwOrd],dwFunOffset);//获取函数名// 根据序号索引到函数名称表中的名字for (DWORD dwIndex &#61; 0; dwIndex ------------序号表的值 对应着 地址表的下标
if (pEIT[dwIndex] &#61;&#61; dwOrd){// 根据序号索引到函数名称表中的名字DWORD dwNameOffset &#61; RVA2OffSet(pENT[dwIndex], pNt);char* pFunName &#61; (char*)((DWORD)lpImage &#43; dwNameOffset);printf("函数名称: %s\n",pFunName);continue;}}printf("\n");}}int _tmain(int argc, _TCHAR* argv[])
{LPCTSTR path &#61; L"C:\\Users\\Denny\\Desktop\\&#xff08;手动查找导入导出表&#xff09;\\&#xff08;手动查找导入导出表&#xff09;\\MFCLibrary1Dll.dll";HANDLE hFile &#61; nullptr;if ( INVALID_HANDLE_VALUE &#61;&#61; (hFile &#61; CreateFile(path, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, NULL) )){return 0;}DWORD dwSize &#61; 0;if ( INVALID_FILE_SIZE &#61;&#61; (dwSize &#61; GetFileSize(hFile, NULL))){CloseHandle(hFile);return 0;}PVOID lpFileImage &#61; nullptr;if (!(lpFileImage &#61; VirtualAlloc(NULL, dwSize, MEM_COMMIT, PAGE_READWRITE))){CloseHandle(hFile);return 0;}DWORD dwRet &#61; 0;//将文件内容读取到内容空间if (! ReadFile(hFile, lpFileImage, dwSize, &dwRet, NULL)){CloseHandle(hFile);VirtualFree(lpFileImage, dwSize, MEM_RELEASE);return 0;}ShowExport(lpFileImage, dwSize);system("pause");return 0;
}



推荐阅读
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 在前两篇文章中,我们探讨了 ControllerDescriptor 和 ActionDescriptor 这两个描述对象,分别对应控制器和操作方法。本文将基于 MVC3 源码进一步分析 ParameterDescriptor,即用于描述 Action 方法参数的对象,并详细介绍其工作原理。 ... [详细]
  • C++: 实现基于类的四面体体积计算
    本文介绍如何使用C++编程语言,通过定义类和方法来计算由四个三维坐标点构成的四面体体积。文中详细解释了四面体体积的数学公式,并提供了两种不同的实现方式。 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
author-avatar
我的未来不叫未来_743
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有