您的位置:首页 > 编程语言 > C语言/C++

c++反汇编代码分析--偷调函数

2010-04-07 01:52 281 查看
推荐阅读:

C++反汇编代码分析–函数调用

C++反汇编代码分析–循环结构

C++反汇编代码分析–偷调函数

走进内存,走进汇编指令来看C/C++指针

注:不知道说“偷调函数”说法合不合适,在此也就这样一说了~

主要有两点:

一、再说C++反汇编函数调用,重点是怎样通过堆栈实现由被调用函数转到调用者

二、在1的基础上,在WinDbg下通过修改EIP实现如下一个功能:

  有两个函数foo()和hack(),在main函数中调用foo,但是在foo执行过程中,通过修改EIP来调用hack函数,最后再回到main中foo函数的下一条语句

一、再说C++反汇编函数调用,重点是怎样通过堆栈实现由被调用函数转到调用者

程序如下(很简单):

#include"stdafx.h"

intMyAdd(inta,intb)
{
returna+b;
}

voidmain()
{
MyAdd(1,2);
}

反汇编后如下:

voidmain()
11:{
00401080pushebp
00401081movebp,esp
00401083subesp,40h
00401086pushebx
00401087pushesi
00401088pushedi
00401089leaedi,[ebp-40h]
0040108Cmovecx,10h
00401091moveax,0CCCCCCCCh
00401096repstosdwordptr[edi]

12:MyAdd(1,2);
00401098push2
0040109Apush1

;程序执行到这,堆栈内容如下(至于为什么是这,请参看《c++反汇编代码分析--函数调用》)



0040109Ccall@ILT+15(hook)(00401014);

--------------------------------开始转入MyAdd函数去执行--------------------------

;在执行0040109Ccall@ILT+15(hook)(00401014)到这句时,F11单步调试,会依次执行下边的反汇编代码:

00401014jmpMyAdd(00401030)

;执行到此句时,ESP和EBP还是原来的值吗?

;我们可能会觉得,现在也没有push操作,ESP和EBP应该还是应该如上图一样没有变化吧

;非也,其实执行到这一句时,已经有一个自动的入栈操作,入栈的是0040109Ccall@ILT+15(hook)(00401014)

;这条指令的下一条指令的地址,具体如下图所示:

;执行到0040109Ccall@ILT+15(hook)(00401014)这条语句时,如图:


;执行到0040109Ccall@ILT+15(hook)(00401014)这条语句,按F11后,如下图:


;此时的堆栈情况如下图




;之后,转入下边的程序执行

5:intMyAdd(inta,intb)
6:{
00401030pushebp


……
   }
……

;执行过ret后,会自动将堆栈中retAddr的值弹给EIP,从而完成从被调用函数MyAdd转到main函数中去执行。
;这一点十分重要,也就是二的理论基础了吧。

00401053popebp
00401054ret

--------------------------MyAdd子函数执行完毕,在此进入main函数执行------------------------------------


004010A1addesp,8
13:}
004010A4popedi
......

二、在一的基础上,在WinDbg下通过修改EIP实现如下一个功能:......

程序如下:

#include<iostream>
usingnamespacestd;
voidfoo()
{
printf("--foo--\n");
}
voidhook()
{
printf("--hook--\n");
}

voidmain()
{
foo();
hook();
}

理论如图:



输出为:

--foo--

--hack--

--hack--

(具体实现参考第一部分结合这里给出的图示,应该很快可以出来了,嘿嘿,困了,偷懒~有时间会将如何看反汇编代码,如何查看寄存器,以及如何在windbg这个终极利器下调试程序等等做下总结,都是很基本的,包括今天费了老大劲,写到半夜的东西,也没有什么用,只是帮助理解,大侠们莫嘲笑,我只是初学阶段,正在努力!)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: