实验说明
return-into-libc 方式(又称 arc injection)的 漏洞利用可以在不注入代码的情况下达到 攻击利用目的
– 使用已经存在代码的地址覆盖返回地址,通常 为一个函数的地址及相应的参数,如 system()、 exec()等
– 当返回时,通过调用 system()、exec()等函数, 执行攻击者指定的系统命令(函数参数中指定)
– 利用 return-into-libc 还可执行一系列函数
实验环境:
系统环境:Linux localhost.localdomain 2.6.9-5.EL #1 Wed Jan 5 19:22:18 EST 2005 i686 i686 i386 GNU/Linux
Gdb 环境:GNU gdb Red Hat Linux (6.1post-1.20040607.62rh) Copyright 2004 Free Software Foundation, Inc.
实验内容: 在调试情况下实现一个 return-into-libc 攻击实例,调用 system()函数在当前目录下创建一个文件
实验操作:
1) 创建实验代码,并进行编译注意,实验前需要先输入命令 sysctl –w kernel.exec-shield=0 //关闭地址随机化。
Gcc 加入-ggdb 选项 #gcc –ggdb ret.c –o ret
2) gdb 调试阶段,并利用找到系统函数地址。
Gdb ret 进入调试界面