zoukankan      html  css  js  c++  java
  • Linux sudo权限提升漏洞(CVE-2019-14287)

    目录

    0x01 漏洞介绍

    0x02 漏洞影响

    0x03 漏洞复现

    0x04 漏洞细节

    0x05 参考

    0x01 漏洞介绍

    此漏洞可以使受限制的用户运行root命令

    0x02 漏洞影响

    1.8.28之前的sudo版本均会受到影响

    此漏洞的利用需要使用户具有sudo的权限

    0x03 漏洞复现

    file

    0x04 漏洞细节

    因为需要用户拥有root权限,这也意味着用户的sudoers中的runas说明符中具有特殊值ALL

    我们这里来查看一下/etc/sudoers

    file

    我们可以看到下面几个用户权限的配置信息,它们的含义是这样的

    授权用户/组 主机=[(切换到哪些用户或组)][是否需要输入密码验证] 命令1,命令2
    

    第一个字段中,不以%开头的,代表“将要授权的用户”,例如其中的root;以%开头的表示“将要授权的组”,比如其中的%admin%sudo

    第二个字段表示允许登陆的主机,ALL表示所有,这里指明的是用户可以在哪些服务器上登陆本服务器来执行sudo命令,比如

    wuxin ALL=/usr/sbin/reboot,/usr/sbin/shutdown
    

    表示的是普通用户wuxin在所有主机上,都可以通过sudo运行reboot和shutdown两个命令

    第三个字段如果省略的话,表示切换到root用户,如果为ALL,则表示可以切换到任何用户,里面的(ALL:ALL)表示的是允许切换到任何(用户:组)

    PS:如果没有省略,必须使用括号将两个值括起来

    第四个参数为NOPASSWD,这个文件中的这个省略掉了,意味着都是需要密码来进行操作的,如果为下面这个样子就不需要输入密码了

    wuxin ALL=(ALL:ALL) NOPASSWD:ALL
    

    第五个参数为授权操作的命令,如果值为ALL的话,就可以执行任意的命令了

    这里解释了这么多,也就是说明了我们这个环境下的所有的用户都是可以执行sudo的。

    在这种情况下,我们就可以使用#uid语法以任意用户ID来运行它

    例如执行

    sudo -u#1234 id -u
    

    将会返回1234

    file

    但是sudo执行前用于更改用户ID的setresuid(2)和setreuid(2),特别对待用户ID-1(或其等效的4294967295),不会更改此用户的ID值,实际上他们返回的值为0

    file

    这是因为sudo本身已经用用户ID 0运行,因此在尝试更改用户ID为-1时,是不会发生任何更改的,另外由于通过-u指定的用户ID在密码数据库是不存在的,因此不会允许任何PAM会话模块

    0x05 参考

    https://www.sudo.ws/alerts/minus_1_uid.html

    文章首发公众号:无心的梦呓(wuxinmengyi)

    这是一个记录红队学习、信安笔记,个人成长的公众号

    扫码关注即可

    file

  • 相关阅读:
    gulp图片压缩 gulp-imagemin
    $q.all() 的异步处理问题
    angular.forEach()
    js判断数据类型是否为字符串
    vue项目build后,服务器中运行程序成功,但是刷新页面以后就挂了
    移动端动态布局 设置字体大小
    js和angularjs之间的相互调用
    关于WebUploader上传文件插件的headers.token拦截问题
    vue+elementUI 时间范围选择器
    深入理解计算机系统_3e 第八章家庭作业 CS:APP3e chapter 8 homework
  • 原文地址:https://www.cnblogs.com/wuxinmengyi/p/11678655.html
Copyright © 2011-2022 走看看