逆向学习之IDA简介
逆向学习之IDA简介
IDA是Windwos下众多调试器工具中颇受欢迎的一种。IDA Pro首先是一个反汇编器,可以显示二进制会变吗(可执行文件或DLL(Dynamic Link Library),动态链接库),它提供的某些高级功能使我们更容易理解汇编代码。其次,它又是一个调试器,用户可以逐条调试二进制文件中的指令,从而确定正在执行哪条指令,以及执行的顺序等。
??IDA PRO是一款交互式反编译工具,功能强大。最主要的特性是交互和多处理器。IDA支持的文件类型丰富,除了常见的PE格式,还支持Windows,DOS,Unix,Mac等平台文件格式。
一、打开文件,关闭文件
打开文件
关闭程序
推荐使用第二种保存方式,如果不想保存,选择最后一个选项
二、窗口介绍:图形 文本 其他窗口介绍
| 导航条 | 意义 |
|---|---|
| 蓝色 | 表示常规的指令函数 |
| 黑色 | 节与节之间的间隙 |
| 银白色 | 数据内容 |
| 粉色 | 表示外部导入符号 |
| 暗黄色 | 表示ida未识别的内容 |
| IDA主界面 | 意义 |
| IDA View | 三种反汇编视图:文本视图、图表视图、路径视图 |
| Hex View | 十六进制窗口 |
| Imports | 导入函数窗口 |
| Struceures | 结构体窗口 |
| Exports | 导出函数窗口 |
| Enums | 枚举窗口 |
| Strings |
三、常用快捷键
| 快捷键 | 功能说明 |
|---|---|
| Enter | 跟进函数实现,查看标号对应的地址 |
| 返回跟进处,返回上一个操作地址 | |
| A |
解释光标处的地址为一个字符串的首地址 /C-->代码/D-->数据/A-->ascii字符串/U-->解析成未定义的内容 |
| B | 十六进制与二进制数转换 |
| C | 解释光标处的地址为一条指令 |
| D | 解释光标处的地址为数据,每按一次将会转换这个地址的数据长度 |
| G | 快速查找对应地址 |
| H | 十六进制与十进制数转换 |
| K | 将数据解释为栈变量 |
| : | 添加注释 |
| R | 编码转换 |
| M | 解释为枚举成员 |
| N | 重新命名 |
| O | 解释地址为数据段偏移量,用于字符串标号 |
| T | 解释数据为一个结构体成员 |
| X | 转换视图到交叉参考模式 |
| Shift + F9 | 添加结构体 |
| 空格 | 切换文本视图与图表视图 |
| ALT + M | 添加标签 |
| CTRL + M | 查看标签 |
| CTRL + S | 查看段的信息 |
| 冒号 | 常规注释 |
| CTRL + F12 | 函数调用图 |
| Ctrl + F9 | 导入c头文件 |
| F5 | 查看伪代码 |
| Alt+T | 搜索文本 |
| Alt+B | 搜索十六进制 |
| ctrl+shift+w | 拍摄IDA快照 |
| u | undefine,取消定义函数、代码、数据的定义 |
| view–>open subviews | 可以恢复你无意中关闭的数据显示窗口 |
| windows–>reset desktop | 可以恢复初始ida布局 |
| option–>font | option–>font |
| option–>general->Auto comments | 自动添加反汇编注释 |
操作演示
直接按空格
显示硬编码:默认对于指令部分是不显示机器码的
CTRL + F12:函数调用图
F12 流程图