news 2026/6/10 11:15:40

PE之代码解析异常表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PE之代码解析异常表

PE之代码解析异常表
1)异常表
异常表(ExceptionTable,注意你拼写的Exection是笔误,正确为Exception)是PE(PortableExecutable)文件格式中用于存储结构化异常处理(SEH)和基于帧的异常处理(EH)相关信息的数据结构,是Windows系统处理程序运行时异常(如内存访问错误,除零错误等)的核心依据。


咱们来看下逆向破解中的典型场景:​
识别程序中的异常处理逻辑边界(比如壳通过异常表实现反调试,代码混淆);
定位恶意代码中隐藏的执行流(异常处理常被用作执行流跳转的后门);
修复脱壳后PE文件的异常表(避免程序运行时崩溃)。


2)解析异常表
解析异常表的核心目标是定位异常表在PE文件中的物理位置,解析表内每一条异常处理记录的结构,提取关键地址信息,最终还原程序的异常处理逻辑;异常表的核心定位逻辑为PE文件的异常表信息首先存储在可选头(OptionalHeader)的DataDirectory数组中,索引为IMAGE_DIRECTORY_ENTRY_EXCEPTION(数值为0x04),该位置会记录异常表的虚拟地址(VirtualAddress,VA,即异常表在内存中的起始地址)和大小(Size,即异常表的总字节数),解析时需先通过该索引找到异常表的VA和Size,再将VA转换为文件中的物理偏移(RawOffset),最终读取并解析表内数据。


3)程序开发流程
前期基本流程和导入表基本大差不差哦
1.文件读取:首先把要分析的EXE或DLL文件以二进制方式打开,将文件里所有内容读到内存里的一个临时区域(咱们叫它buf)。
2.定位DOS头:接着把这个buf转换成能识别PE文件开头DOS头的格式(PIMAGE_DOS_HEADER),校验DOS头的e_magic字段是否为IMAGE_DOS_SIGNATURE(0x5A4D,即"MZ"),确认是有效PE文件。
3.定位NT头:找到DOS头里的e_lfanew这个关键值,用它加上buf的起始位置定位到PE文件的核心NT头(PIMAGE_NT_HEADERS32/PIMAGE_NT_HEADERS64),校验NT头的Signature字段是否为IMAGE_NT_SIGNATURE(0x00004550,即"PE")。
4.区分PE位数:通过NT头中OptionalHeader.Magic字段判断PE文件是32位(IMAGE_NT_OPTIONAL_HDR32_MAGIC)还是64位(IMAGE_NT_OPTIONAL_HDR64_MAGIC)。
5.获取异常目录(ExceptionDirectory)
从NT头的OptionalHeader.DataDirectory数组中,根据IMAGE_DIRECTORY_ENTRY_EXCEPTION索引定位到异常目录结构体(PIMAGE_DATA_DIRECTORY):
64位PE文件使用pNt64->OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_EXCEPTION]
32位PE文件使用pNt32->Optiona

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/6 20:41:42

计算机Java毕设实战-基于SpringBoot的水族馆商品销售与经营管理系统基于vue的水族馆观赏鱼商品销售与经营管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/5/23 19:16:33

Java毕设选题推荐:基于SpribgBoot的新鲜蔬果生鲜团购平台基于SpribgBoot的海鲜肉类生鲜团购平台【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/6/9 12:05:01

6款AI论文工具解析:高效改写与降重策略

开头总结工具对比(技能4) �� 为帮助学生们快速选出最适合的AI论文工具,我从处理速度、降重效果和核心优势三个维度,对比了6款热门网站,数据基于实际使用案例: 工具名称 处理速度 降…

作者头像 李华
网站建设 2026/5/24 8:53:53

【路径规划】基于RRT算法结合Dubins实现车辆路径规划附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎 往期回顾关注个人主页:Matlab科研工作室 👇 关注我领取海量matlab电子书和数学建模资料 &#x1…

作者头像 李华
网站建设 2026/6/4 20:32:25

【iManus】AI 编码代理中Skills、MCP、Prompt、SubAgent的基本概念和定义

文章目录 AI 编码代理中 Skills、MCP、Prompt、SubAgent 的基本概念和定义 概述 1. SubAgent(子代理) 1.1 基本定义 1.2 核心特性 1.3 配置结构 1.4 配置格式 1.5 核心配置字段 1.6 使用场景 1.7 典型案例模板 2. MCP(Model Context Protocol,模型上下文协议) 2.1 基本定义…

作者头像 李华