CTF-All-In-One/doc/6.1.6_pwn_defconctf2015_fuckup.md

40 lines
1.2 KiB
Markdown
Raw Normal View History

2017-11-23 20:32:22 +07:00
# 6.1.6 pwn DefconCTF2015 fuckup
- [ret2vdso 原理](#ret2vdso-原理)
- [题目解析](#题目解析)
2018-05-01 20:57:53 +07:00
- [漏洞利用](#漏洞利用)
2017-11-23 20:32:22 +07:00
- [参考资料](#参考资料)
2017-12-05 18:06:40 +07:00
[下载文件](../src/writeup/6.1.6_pwn_defconctf2015_fuckup)
2017-11-23 20:32:22 +07:00
2017-12-05 18:06:40 +07:00
## ret2vdso 原理
2018-08-05 16:43:10 +07:00
2017-11-24 17:48:00 +07:00
在你使用 `ldd` 命令时,通常会显示出 vDSO如下
2018-08-05 16:43:10 +07:00
```text
2017-11-24 17:48:00 +07:00
$ ldd /usr/bin/ls
linux-vdso.so.1 (0x00007ffff7ffa000)
libcap.so.2 => /usr/lib/libcap.so.2 (0x00007ffff79b2000)
libc.so.6 => /usr/lib/libc.so.6 (0x00007ffff75fa000)
/lib64/ld-linux-x86-64.so.2 => /usr/lib64/ld-linux-x86-64.so.2 (0x00007ffff7dd8000)
```
2018-08-05 16:43:10 +07:00
32 位程序则会显示 `linux-gate.so.1`,都是一个意思。
2017-11-24 17:48:00 +07:00
2017-11-23 20:32:22 +07:00
## 题目解析
2018-08-05 16:43:10 +07:00
```text
$ file fuckup
2017-11-25 15:45:09 +07:00
fuckup: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), statically linked, stripped
2018-08-05 16:43:10 +07:00
$ checksec -f fuckup
2017-11-25 15:45:09 +07:00
RELRO STACK CANARY NX PIE RPATH RUNPATH FORTIFY Fortified Fortifiable FILE
No RELRO No canary found NX enabled No PIE No RPATH No RUNPATH No 0 0 fuckup
```
2017-11-23 20:32:22 +07:00
2018-05-01 20:57:53 +07:00
## 漏洞利用
2017-11-23 20:32:22 +07:00
## 参考资料
2018-08-05 16:43:10 +07:00
2017-11-24 17:48:00 +07:00
- `man vdso`
- [Return to VDSO using ELF Auxiliary Vectors](http://v0ids3curity.blogspot.in/2014/12/return-to-vdso-using-elf-auxiliary.html)