3.0 熟悉IDAPro静态反汇编器
IDA Pro 是一种功能强大且灵活的反汇编工具,可以在许多领域中发挥作用,例如漏洞研究、逆向工程、安全审计和软件开发等,被许多安全专家和软件开发者用于逆向工程和分析二进制代码。它支持大量的二进制文件格式和CPU架构,并提供了强大的反汇编和反编译功能。使用IDA Pro,用户可以查看和编辑汇编代码、查看函数和程序结构,并分析代码执行逻辑和漏洞。此外,IDA Pro还具有脚本编程和插件扩展功能,使用户能够轻松自定义和改进其功能。

IDA官方网站:https://hex-rays.com/
IDA的启动非常简单,只需要双击打开ida.exe即可,打开后读者可看到如下图所示的提示界面,当然读者如果需要逆向分析64位应用程序则需要打开文件内的ida64.exe即可,一般而言读者可通过New按钮来选择新建一个反汇编任务,也可以直接通过Go按钮来直接进入反汇编工具主页,当然如果读者有以前分析过的工程项目则可以通过Previous按钮快速跳转到待分析项目中;

我们以New为例,当打开后则提示读者需要选择一个被分析文件,当选择后会自动弹出如下所示的选项卡,选项卡中已经为我们识别出待分析程序的相关内容,读者只需要点击OK按钮即可打开IDA桌面环境;

当读者成功加载了被分析文件,则IDA会呈现出如下图所示的,其中最左侧的Functions列表代表的是当前IDA所分析出的内部函数,这些函数片段通常是编程者自己的一些子过程以及一些第三方API接口,桌面的右侧最大的部分则是IDA的主要工作台,其中IDA View-A代表的是当前被分析程序的反汇编代码,Hex View-1则是十六进制格式的机器码,Structures代表的是IDA所解析出来的结构体参数,Enums代表的是枚举类型的定义数据,Imports是导入表,Exports则是导出表。在IDA的最底部则是输出信息,此处的信息有IDA自身信息,也有程序调试信息等;

在桌面的最顶端是IDA的彩色水平带也叫做导航带,导航带中是被加载文件地址空间的线性视图,默认情况下它会呈现出二进制文件的整个地址范围,读者可以右击导航带内任何位置,并选择一个可用的缩放选项,放大或缩小显示的地址范围,同时导航带中会存在一个黄色的指针,当点击后会提示用户当前指针所对应的文件位置,该导航带对于代码分析可以起到很好的预览目的。

在IDA窗口中读者最需要关注的窗口则是IDA View-A反汇编窗口,在反汇编窗口中读者可根据自身需求对代码进行分析,其次IDA窗口中可实现动态绘图的功能,当读者需要对特定区域中特定函数进行绘图时只需要选中该函数的头部,并右键选择GraphView按钮,则可将当前函数绘制成图;

当绘制成流程图以后,读者可通过按下Ctrl+鼠标中键滚动以此来实现对流程图的放大和缩小,在绘图模式下读者也可以通过点击不同的分支结构从而实现跳转到不同位置处,在绘图模式下,一般而言绿色线条代表跳转为真,红色线条代表跳转为假,而蓝色线条则代表无条件跳转,另外按下空格还可实现汇编与绘图窗口的灵活切换,如下图所示;

除了简单的绘图功能外IDA还提供了F5插件,运用该插件可对特定区域反汇编代码生成C语言格式的流程代码,读者只需要选中一段内存代码片段,并按下F5即可看到如下伪代码输出格式;

针对IDA工具的使用技巧还有许多,此处仅仅只是抛砖引玉带读者入门,如果需要获取更多关于IDA工具的使用方法,还得通过不同的积累学习,本章不可能将IDA中的每一个细节都概括到;
3.0 熟悉IDAPro静态反汇编器的更多相关文章
- C++ 基于Capstone实现反汇编器
Capstone是一个反汇编框架,提供了一个简单.轻量级的API接口,可透明地处理大多数流行的指令体系,包括x86/x86-64.ARM及MIPS等.Capstone支持C/C++和Python,并且 ...
- longblogV1.0——我的静态博客发布系统
longblogV1.0——我的静态博客发布系统 环境依赖: python3-markdown 作者:IT小小龙个人主页:http://long_python.gitcafe.com/电子邮箱:lon ...
- 转: MyEclipse 10.0,9.0,8.0 下添加jadClipse反编译插件
MyEclipse 10.0,9.0,8.0 下添加jadClipse反编译插件 (2012-11-19 15:36:35) 转载▼ 标签: myeclipse jad 反编译 插件 it 分类: M ...
- 基于ARM处理器的反汇编器软件简单设计及实现
写在前面 2012年写的毕业设计,仅供参考 反汇编的目的 缺乏某些必要的说明资料的情况下, 想获得某些软件系统的源代码.设计思想及理念, 以便复制, 改造.移植和发展: 从源码上对软件的可靠性和安全性 ...
- vs2010下编译osip2和eXosip2的4.0.0版的静态库及搭建开发环境
转载于:http://blog.csdn.net/lbc2100/article/details/48293911 本文为参考网上的动态库的方式,进行静态库的实现,在此对动态库的作者表示感谢. 第一步 ...
- (二)SpringBoot2.0基础篇- 静态资源的访问及Thymeleaf模板引擎的使用
一.描述 在应用系统开发的过程中,不可避免的需要使用静态资源(浏览器看的懂,他可以有变量,例:HTML页面,css样式文件,文本,属性文件,图片等): 并且SpringBoot内置了Thymeleaf ...
- ASP.NET Core 1.0基础之静态文件处理
来源 这些HTML , CSS files, image files, 和JavaScript这些静态文件,是ASP.NET能够直接响应给客户端的.本文详述下ASP.NET和静态文件的关系. Serv ...
- 使用springboot 2.0后,静态资源默认路径无法访问
原因在于:META-INF/resources / resources / static / public 都是spring boot 认为静态资源应该放置的位置,会自动去寻找静态资源 然而,在2.0 ...
- ubuntu16.0.4 设置静态ip地址
由于Ubuntu重启之后,ip很容易改变,可以用以下方式固定ip地址 1.设置ip地址 vi /etc/network/interface # The loopback network interfa ...
- 【转】编译Lua5.3.0的iOS静态库
This is a tutorial on how to compile Lua 5.3.0 as an iOS static library (liblua.a) on Mac OS X 10.10 ...
随机推荐
- Github 自建一个 Helm Charts 库
前言 在构建私有的 charts 仓库之前,有几个先决条件: Helm 已经安装,版本号是 v3 拥有一个 Github 账号 初始化仓库 在 github 仓库上新建一个仓库,我这里命名为 helm ...
- 微软的一些公开课,Python、机器学习、SQL、AI,全部免费
大家好,我是老章,刷X看到一位博主Alif Hossain@alifcoder总结了微软的一些公开课,全部免费,蛮不错的.感兴趣可以学一波,还能领徽章. 1. 机器学习简介 本课程是学习机器学习基础知 ...
- SpringBoot 学习笔记:运维篇
SpringBoot程序的打包和运行 开发部门使用Git.SVN等版本控制工具上传工程到版本服务器 服务器使用版本控制工具下载工程 服务器上使用Maven工具在当前真机环境下重新构建项目 启动服务 程 ...
- 0x53 动态规划-区间DP
A: 石子合并 所求问题:1到n这些石子合并最少需要多少代价 由于石子合并的顺序可以任意,我们将石子分为两个部分 子问题:1到k这堆石子合并,k+1到n这堆石子合并,再把两堆石子合并,需要多少代价\( ...
- rabbitMq消息持久化机制,和延时队列
1.RabbitMQ的一大特色是消息的可靠性,那么它是如何保证消息可靠性的呢? 消息持久化.可以将Queue,Exchange,Message都设置为可持久化的.为了保证RabbitMQ在退出,服务重 ...
- 如何在编码阶段减少代码中的bug?
前言 作为一名合格的程序员,不写bug是不可能的.如何花费最少的时间来修复bug呢? 在编码阶段借助一些静态分析工具往往可以事半功倍,减少代码中的bug. 静态分析工具能够在代码未运行的情况下分析源代 ...
- uni-app点赞效果
- 实现不限层级的Element的NavMenu
做管理后台开发的时候,需要用到Element的NavMenu组件,于是乎,翻开文档,大致是这样实现的. <el-menu> <el-menu-item index="1&q ...
- 国内服务器 3 分钟将 ChatGPT 接入微信公众号(超详细)
原文链接:https://forum.laf.run/d/364 最近很火的ChatGPT可以说已经满大街可见了,到处都有各种各样的体验地址,有收费的也有免费的,总之是五花八门.花里胡哨. 所以呢,最 ...
- P1955【绿】
这道题是标准的"离散化+并查集"模版题,通过这道题彻底理解了并查集,同时还意识到了我之前一直用map来实现离散化的方法其实是最简单但是最慢的方法,以这道题为例,map导致时间消耗有 ...