Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matrix1001/nadbg
👀Dynamic memory watcher/tracer/analyzer for CTF pwn
https://github.com/matrix1001/nadbg
ctf debugger memory-analysis pwn
Last synced: about 2 months ago
JSON representation
👀Dynamic memory watcher/tracer/analyzer for CTF pwn
- Host: GitHub
- URL: https://github.com/matrix1001/nadbg
- Owner: matrix1001
- Created: 2019-05-03T02:54:24.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-07-11T00:38:44.000Z (over 4 years ago)
- Last Synced: 2024-08-05T17:38:26.521Z (5 months ago)
- Topics: ctf, debugger, memory-analysis, pwn
- Language: Python
- Homepage:
- Size: 146 KB
- Stars: 52
- Watchers: 4
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-hacking-lists - matrix1001/nadbg - 👀Dynamic memory watcher/tracer/analyzer for CTF pwn (Python)
README
# nadbg - Not A Debugger
nadbg is designed to analyze memory of the Linux process.
__core feature__
- ptrace free
- extensible
- easy to use
- heap analyze (with heapinspect)
- blabla......__future feature__
- ASLR/PIE support
- blabla......# usage
before you use it, execute this.
```sh
git submodule update
```start this application.
```py
python nadbg.py
```use `help` or `?` to get some help.
## attach
nadbg support `path`, `binary name`, `pid`.
```
[nadbg] /bin/cat > attach /usr/bin/cat
attach /usr/bin/cat success. pid: 10696
[nadbg] /usr/bin/cat >
``````
[nadbg] > attach cat
attach cat success. pid: 10696
[nadbg] cat >
``````
[nadbg] > attach 10696
attach 10696 success. pid: 10696
[nadbg] 10696 >
```## memory dump
memory dump is similar to those of `pwndbg`.
```
[nadbg] /usr/bin/cat > dq 0x7fffffffe270 4
0x7fffffffe270: 0000000000000001 00007fffffffe588
0x7fffffffe280: 0000000000000000 00007fffffffe595
[nadbg] /usr/bin/cat > dd 0x7fffffffe270 4
0x7fffffffe270: 00000001 00000000 ffffe588 00007fff
[nadbg] /usr/bin/cat > db 0x7fffffffe270 16
0x7fffffffe270: 01 00 00 00 00 00 00 00 88 e5 ff ff ff 7f 00 00
[nadbg] /usr/bin/cat > ds 0x7fffffffe588 13
'/usr/bin/cat\x00'
```## memory search
memory search is similar to that of `peda`.
```
[nadbg] /usr/bin/cat > find /bin/cat
[0] 0x7fffffffe58c
[1] 0x7fffffffefcd
[2] 0x7fffffffefef
[nadbg] /usr/bin/cat > find 0x7fffffffe588
[0] 0x55555555f278
[1] 0x7fffffffe278
```## memory watch
`memory watcher` is designed to scan/print memory.
well, it's designed to free you from `dq`, `dq` and `dq`. :)
```
[nadbg] /usr/bin/cat > wq 0x7fffffffe278 1
[nadbg] /usr/bin/cat > ws 0x7fffffffe588 13
[nadbg] /usr/bin/cat > p
[0] 1 qword
0x7fffffffe278: 00007fffffffe588
[1] 13 str
0x7fffffffe588: '/usr/bin/cat\x00'
[nadbg] /usr/bin/cat >
```also, there's a loop printer for you. by default, it has a scan interval of 1 sec. it will only print message when the watched memory changed.
```
[nadbg] /usr/bin/cat > print_forever
[0] 1 qword
0x7fffffffe278: 00007fffffffe588
[1] 13 str
0x7fffffffe588: '/usr/bin/cat\x00'[0] 1 qword
0x7fffffffe278: 00007fffffffe588
[1] 13 str
0x7fffffffe588: '\xef\xbe\xad\xde/bin/cat\x00'[0] 1 qword
0x7fffffffe278: 00007fffdeadbeef
[1] 13 str
0x7fffffffe588: '\xef\xbe\xad\xde/bin/cat\x00'^C
KeyboardInterrupt
```just use `ctrl + c` to stop it.
## process info
just some process infomation you need to know.
`info`
```
[nadbg] cat > info
process path: /usr/bin/cat
arch: 64
libc: /usr/lib/x86_64-linux-gnu/libc-2.28.so
prog address: 0x555555554000
libc address: 0x7ffff7dec000
````vmmap`
```
[nadbg] cat > vmmap
Map("/usr/bin/cat", 0x555555554000, 0x555555556000, "r--p")
......
Map("/usr/lib/x86_64-linux-gnu/libc-2.28.so", 0x7ffff7dec000, 0x7ffff7e0e000, "r--p")
......
Map("[stack]", 0x7ffffffde000, 0x7ffffffff000, "rw-p")
````canary`
```
[nadbg] cat > canary
0x4456b914aa845400
````address`
```
[nadbg] cat > info bases
[vdso]: 0x7ffff7fd3000
libc: 0x7ffff7dec000
ld-2.28.so: 0x7ffff7fd5000
heap: 0x0
mapped: 0x7ffff7fa9000
prog: 0x555555554000
stack: 0x7ffffffde000
[vvar]: 0x7ffff7fd0000
```well, `heap: 0x0` means there is no heap.
## heapinspect
Just use `hi` to print help message. Then use it.
```
[nadbg] /usr/bin/dash > hi heap
========================= HeapInspect =========================
libc_version:2.28
arch:64
tcache_enable:True
libc_base:0x7f1e68ab6000
heap_base:0x563073660000(0x80) entries[6] -> 0x563073660bc0
(0x210) entries[31] -> 0x563073660c40
top: 0x563073660e40
last_remainder: 0x0
unsortedbins: None
[nadbg] /usr/bin/dash >
```## other?
tell me what you want. then i make one for you.