《REVERSING:逆向工程揭密》——随笔笔记

设置消息断点步骤(OllyDbg):
分析程序(Ctrl+A)->找到窗口回调->右键分析假定参数->右键断点WinProc断点->设置要截获的消息

一、调试器
1.用户模式调试器

  • OllyDbg:强大的反汇编能力,调试从WinMain开始,在所有静态链接DLL初始化完成之后,免费软件
  • WinDbg:反汇编能力有限,与操作系统的集成性方面超过OllyDbg,可以在静态链接DLL初始化之前单步调试,免费软件
  • IDA Pro:强大的反汇编器+用户模式调试器
  • PEBrowse Professional Interactive:中间语言调试器+针对.NET程序的反汇编器,免费软件

2.内核模式调试器

  • WinDbg:与运行WinDbg GUI的系统相互独立的系统上远程执行的
  • Numega SoftlCE:目前最流行的逆向调试器,允许进行本地内核调试。本质上是一个Windos内核驱动程序,总的来说优于WinDbg

二、系统监控工具

  • FileMon:监控程序和操作系统之间所有文件系统级的通信,以及显示在系统中运行的每个进程所产生的文件I/O,可以观察到每个被打开的文件或目录,以及系统中任何进程执行的读写操作
  • TCPView:监控每个进程的所有活动的TCP和UDP网络链接,不能显示真正的通信
  • TDIMon:类似TCPView,提供系统中所有进程执行的任何套接字级(socket-level)操作的信息
  • RegMon:注册表活动的监控器,汇报来自每个程序对注册表的所有访问
  • PortMon:物理端口监控器,监控系统中所有的并行和串行I/O通信
  • WinObj:以层次化(分级)的视图显示系统中的命名对象
  • Process Explorer:任务管理器增强版

三、修补工具

  • Hex Workshop:十六进制转储和修补工具,可以做文件甚至是整个磁盘的转储和修补工作,不支持反汇编或汇编。除了是一种修补工具外,还是一款数据逆向工程程序,支持把数据转换为有组织的数据结构,不免费

四、可执行程序转储工具

  • DUMPBIN:微软控制台模式下的工具,用来转储可移植的可执行程序文件的多个不同部分
  • PEView:具有图形化用户界面,能够将所有重要的PE数据结构以良好的GUI方式显示,提供了显示文件中选定区域内原始字节的原始视图
  • PEBrowse Professional:PE转储+反汇编,能转储所有与PE相关的文件头,可以作为原始数据和结构化的文件头信息
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
第三卷************** 不错的PDF电子书,共3个分卷,点我名字可以找全 第1部分 逆向101 第1章 基础 3 1.1 什么是逆向工程 3 1.2 软件逆向工程:逆向 4 1.3 逆向应用 4 1.3.1 与安全相关的逆向 5 1.3.2 软件开发中的逆向 8 1.4 底层软件 9 1.4.1 汇编语言 10 1.4.2 编译器 11 1.4.3 虚拟机和字节码 12 1.4.4 操作系统 13 1.5 逆向过程 13 1.5.1 系统级逆向 14 1.5.2 代码级逆向 14 1.6 工具 14 1.6.1 系统监控工具 15 1.6.2 反汇编器 15 1.6.3 调试器 15 1.6.4 反编译器 16 1.7 逆向合法吗? 17 1.7.1 互操作性 17 1.7.2 竞争 18 1.7.3 版权法 19 1.7.4 商业机密和专利权 20 1.7.5 美国数字千禧版权法 20 1.7.6 DMCA案例 22 1.7.7 许可证协议 23 1.8 代码范例与工具 23 1.9 结论 23 第2章 底层软件 25 2.1 高阶视角 26 2.1.1 程序结构 26 2.1.2 数据管理 29 2.1.3 控制流 32 2.1.4 高级语言 33 2.2 低阶视角 37 2.2.1 底层数据管理 37 2.2.2 控制流 43 2.3 汇编语言101 44 2.3.1 寄存器 44 2.3.2 标志位 46 2.3.3 指令格式 47 2.3.4 基本指令 48 2.3.5 范例 52 2.4 编译器和编译入门 53 2.4.1 定义编译器 54 2.4.2 编译器架构 55 2.4.3 列表文件 58 2.4.4 专用编译器 59 2.5 执行环境 60 2.5.1 软件执行环境(虚拟机) 60 2.5.2 现代处理器的硬件执行环境 63 2.6 结论 68 第3章 Windows基础知识 69 3.1 组件及基本架构 70 3.1.1 简要回顾 70 3.1.2 特征 70 3.1.3 支持的硬件 71 3.2 内存管理 71 3.2.1 虚拟内存和分页 72 3.2.2 工作集 74 3.2.3 内核内存和用户内存 74 3.2.4 内核内存空间 75 3.2.5 区段对象 77 3.2.6 VAD树 78 3.2.7 用户模式的内存分配 78 3.2.8 内存管理API 79 3.3 对象与句柄 80 命名对象 81 3.4 进程与线程 83 3.4.1 进程 84 3.4.2 线程 84 3.4.3 运行状态切换 85 3.4.4 同步对象 86 3.4.5 进程初始化顺序 87 3.5 应用程序编程接口 88 3.5.1 Win32 API 88 3.5.2 本地API 90 3.5.3 系统调用机制 91 3.6 可执行文件格式 93 3.6.1 基本概念 93 3.6.2 映像区段(Image Sections) 95 3.6.3 区段对齐(Section Alignment) 95 3.6.4 动态链接库 96 3.6.5 头部 97 3.6.6 导入与导出 99 3.6.7 目录 99 3.7 输入与输出 103 3.7.1 I/O系统 103 3.7.2 Win32子系统 104 3.8 结构化异常处理 105 3.9 结论 107 第4章 逆向工具 109 4.1 不同的逆向方法 110 4.1.1 离线代码分析 110 4.1.2 现场代码分析 110 4.2 反汇编器——ILDasm 110 4.3 调试器 116 4.3.1 用户模式调试器 118 4.3.2 内核模式调试器 122 4.4 反编译器 129 4.5 系统监控工具 129 4.6 修补工具 131 Hex Workshop 131 4.7 其他类型的逆向工具 133 可执行程序转储工具 133 4.8 结论 138 第2部分 应用逆向 第5章 未公开的技术 141 5.1 逆向和互操作性 142 5.2 基本原则 142 5.3 定位未公开的API函数 143 我们要找什么? 144 5.4 案例研究:NTDLL.DLL中的 5.4 Generic Table API 145 5.4.1 RtlInitializeGenericTable 146 5.4.2 RtlNumberGenericTableElements 151 5.4.3 RtlIsGenericTableEmpty 152 5.4.4 RtlGetElementGenericTable 153 5.4.5 RtlInsertElementGenericTable 168 5.4.6 RtlLookupElementGenericTable
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值