IDA Pro > IDA Pro教程 > 使用技巧 > 如何在IDA反编译窗口中编辑函数

如何在IDA反编译窗口中编辑函数

发布时间:2021-03-18 09: 45: 35

IDA是一款用于多个平台系统上的文件反编译软件,它通过递归下降的方式帮我们在加载文件的同时自动分析反编译文件,并将结果写入到对应生成的数据库中,供多方查看编辑。

在初步分析过后,我们有时候会希望能够自主编辑反编译窗口中的函数,例如当我们需要干预调整IDA反编译代码中的错误或者是需要优化代码以节省编码器空间时,都需要手动修改函数。在本节中就IDA编辑函数的功能进行演示讲解。

一、编辑函数

编辑函数的操作很简单,我们在IDA的函数窗口中,右键点击需要编辑的函数,如下图的“sub_401550”函数,然后在右键菜单中选择“Edit function”就可以进入编辑此函数的界面。

图1:点击编辑函数

编辑函数界面如下图2所示,其中有非常多可以自定义编辑的项目,下面我们来一个个的进行讲解。

图2:编辑函数界面

二、参数讲解

一般来说,IDA给我们反编译之后,函数名都是以sub开头的,这其实不适合我们进行理解,因此我们可以在“Name of function”项中将函数名改为便于理解的函数名,最好函数名与函数的功能是相关的。

图3:修改函数名

 “Start address”表示函数的起始地址,也就是函数中第一条指令的地址,一般来说IDA会自动进行识别。

“End address”是函数中最后一条指令的地址,这个地址相比于起始地址,编辑的可能性要更高些。因为起始地址是明确的,而结束地址会因为函数返回语句而产生不确定性,有时候就需要我们手动修改。

图4:起始结束地址

右侧的复选框中,可以编辑函数的特性,这些都是可启用可禁用的函数属性。

“Does not return”表示不返回函数调用方(不是不返回结果),启用之后,IDA函数会一直执行下去;

“Far function”用于将函数标记为“远函数”,调用该函数时,函数的调用方需要指定一个段和一个偏移值;

“Library function”表示将函数标记为“库函数”,标记之后,IDA会将此函数根据库函数的颜色进行显示,与非库函数区分开。

“Static function”会在函数特性列表上显示静态修饰符。

“BP based frame”,该特性表示函数利用了一个帧指针;“BP equals to SP”表示函数将帧指针配置为在进入一个函数时指向栈帧的顶端。

图5:特性复选框

有时IDA会对函数的局部变量数量判断错误,此时我们就可以通过“Local variables area”进行编辑填写。

图6: 局部变量区

以上主要讲解了IDA编辑函数界面中几项较为常用参数的相关概念。关于IDA的函数编辑,还是得我们自己根据实际使用情况进行使用,这项功能是我们利用IDA进行文件反编译的关键功能之一。了解此功能之后,我们才能在IDA的使用上更进一步。

作者署名:包纸

展开阅读全文

标签:IDA反编译软件

读者也访问过这里:
邀请您进入交流群 点击扫码
400-8765-888 kefu@makeding.com

专业销售为您服务

欢迎添加好友,了解更多IDA优惠信息,领逆向工程学习资料礼包1份!
热门文章
exe反编译工具哪个好?反编译能力强的工具盘点
随着软件技术的发展,exe(可执行文件)已经成为了电脑、手机等多个平台上的主要软件运行格式,而对于exe文件的反编译也成为了逆向工程中不可缺少的一个步骤。本文将介绍一些常用的exe反编译工具,并评价其优缺点,帮助读者选择合适的工具。
2023-04-12
idapro怎么改为中文
IDA Pro是一款功能强大的反汇编和反编译工具,广泛应用于逆向工程和软件开发领域。在使用IDA Pro时,如果我们不习惯英文界面,可以将其改为中文界面。本文将介绍IDA Pro怎么改为中文界面。IDA Pro界面改成中文主要有两种方法,下面是详细介绍。
2023-04-19
c++反编译工具有哪些
反编译C++代码的工具一般是针对可执行文件和库文件的反汇编和逆向分析工具。本文将给大家介绍c++反编译工具有哪些的内容。市面说的c++反编译工具有很多,下面介绍几款使用认识较多的软件。
2023-04-23
ida怎么查找字符串 ida字符串窗口快捷键
在数字化时代,逆向工程作为解密软件和分析程序的关键技术,正日益受到广泛关注。在逆向分析的过程中,IDA(Interactive DisAssembler)是一款备受推崇的工具,它为逆向工程师们提供了强大的功能和灵活的操作。本文将带您深入探讨如何在IDA中查找字符串,优化字符串窗口的使用,并探讨IDA如何将变量转换成字符串,帮助您更加熟练地驾驭这一工具,为逆向分析的世界增添一抹精彩。
2023-09-27
ida如何转伪代码 ida伪代码怎么看
IDA Pro是一款常用的反汇编和反编译工具,可以帮助我们分析二进制文件的实现细节和执行过程,以便更好地理解程序的执行过程和逻辑。在进行逆向工程的过程中,我们经常需要将反汇编结果转换为伪代码,以便更好地进行分析和修改。本文将介绍如何使用IDA Pro转换为伪代码,并简单讲解ida伪代码怎么看。
2023-04-14
最新文章
IDA TLS回调怎么定位 IDA TLS回调入口怎么确认
做壳、反调试和早期初始化分析时,TLS回调经常比OEP更早执行,所以一旦漏掉,后面的控制流判断就容易偏。微软的PE规范写得很明确,TLS目录里有一个【Address of Callbacks】字段,它指向一个以空指针结尾的回调函数数组,数组里的多个回调会按地址出现顺序被调用。Hex-Rays早期发布说明也提到,IDA对PE文件已经能够识别TLS callback entries并添加注释。
2026-04-13
IDA vtable怎么识别 IDA vtable调用关系怎么梳理
在IDA里看C++程序,vtable这件事最怕的不是找不到,而是看到了却没真正认出来。很多人一开始只是顺着函数跳,看见一串函数指针就觉得像虚表,可继续往下追时,this指针不稳、虚调用显示不完整、继承关系也对不上,最后越看越乱。Hex-Rays官方文档其实把关键前提说得很明确,IDA和反编译器能利用VFT也就是虚函数表生成更清楚的虚调用表达,但前提是类类型、虚表指针名字和目标编译器设置要尽量对上。
2026-04-13
IDA switch识别失败怎么办 IDA switch跳转表怎么手动修复
IDA里遇到switch识别失败,真正难的通常不是报错本身,而是后面伪代码会跟着断,交叉引用和分支关系也会一起变乱。Hex-Rays官方说明很直接,switch分析失败本质上是间接跳转没有被正确识别,这时优先级最高的不是硬改伪代码,而是先让跳转表重新被分析出来。
2026-04-13
IDA段权限怎么修改 IDA段权限识别错误怎么修正
在IDA里,段权限看起来只是几个小勾选,但它影响的不只是显示。权限设错以后,轻一点会让段列表里的读写执行状态看着别扭,重一点会把反编译判断也带偏。Hex-Rays官方文档里写得很明确,段属性窗口可以直接改Read、Write、Execute,段列表里也会显示R、W、X、D、L这些标志;另外,反编译器会把“没有写权限的段”当成常量内存来处理,所以写权限识别错了,伪代码结果也可能跟着失真。
2026-04-10
IDA重定位表怎么看 IDA重定位表缺失时怎么判断模块类型
做逆向时,重定位信息往往不只是一个附属表,它会直接影响你对装载方式、模块边界和地址修正逻辑的判断。很多人进到IDA以后先找一个名叫重定位表的独立窗口,结果越找越乱。更实用的做法,是先分清文件格式,再在IDA里结合【Segments】、【Imports】、【Exports】和【Hex dump】去看对应区域,因为Hex-Rays官方文档明确给出了这些子视图和重定位修正相关的【Rebase program】入口,而PE和ELF的官方格式文档又分别定义了重定位区到底放在哪里、记录长什么样。
2026-04-10
IDA字节序列怎么搜索 IDA字节序列搜索不到怎么排查
在IDA里找字节序列,最容易出问题的不是入口找不到,而是把“搜文件里的原始字节”“搜反汇编文本”“搜立即数”混到一起用了。Hex-Rays官方文档把这几类搜索分得很清楚,字节序列对应的是【Search】里的“Search for substring in the file”,它搜的是正在分析的文件二进制内容,不是屏幕上看到的反汇编文本。
2026-04-10

通过微信咨询我们

欢迎添加好友,了解更多IDA优惠信息,领取逆向工程学习资料礼包1份!

读者也喜欢这些内容: