首页 > 系统服务 > 详细

Linux权限管理:setUID 和 setGID

时间:2019-11-08 11:19:09      阅读:112      评论:0      收藏:0      [点我收藏+]

1、setUID 和 setGID 的功能详解

  setuid 功能:

  1、只有可执行的二进制文件程序才能设定 SUID 权限(前提)

  2、命令执行者要对该程序有执行(x)权限(必要条件)

  3、命令执行者再执行该程序时获得该程序文件属主的身份

  4、setuid 权限只在该程序执行过程中生效

  setgid 功能: -- 对文件而言

  1、只有可执行的二进制程序设置SGID

  2、命令执行者要对该程序拥有执行(x)权限

  3、命令执行再执行程序的时候,组身份升级为该程序文件的属组

  4、setgid 权限童谣只在该程序执行过程中有效


  setuid 和setgid位是让普通用户可以以root用户的角色运行只有root帐号才能运行的程序或命令。比 如我们用普通用户运行passwd命令来更改自己的口令,实际上最终更改的是/etc/passwd文件我们知道/etc/passwd文件是用户管理的 配置文件,只有root权限的用户才能更改
  技术分享图片

  作为普通用户如果修改自己的口令通过修改/etc/passwd肯定是不可完成的任务,但是不是可以通过一个命令来修改呢答案是肯定的,作为普通用 户可以通过passwd 来修改自己的口令这归功于passwd命令的权限我们来看一下;
  技术分享图片

  因为/usr/bin/passwd 文件已经设置了setuid 权限位(也就是r-s--x--x中的s),所以普通用户能临时变成root,间接的修改/etc/passwd,以达到修改自己口令的权限
  我们在Linux 系统中的超级权限的控制中 有提到过我们知道Linux的用户管理是极为严格的,不同的用户拥有不同的权限,为了完成只有root用户才能完成的工作,我们必须为普通用户提升权 限,最常用的方法就是su或sudo虽然setuid 和setgid也是让普通用户超越自身拥有的普通权限达到root权限的方法,但我不推荐大家使用,因为它能为系统带来隐患!!
  注意:setuid和setgid会面临风险,所以尽可能的少用

2、setuid和setgid的实例应用
  我们想让一个普通用户 qiuyu 拥有root用户拥有超级rm删除权限,我们除了用su或sudo 临时切换到 root身份操作以外,还能怎么做呢?

  技术分享图片

  技术分享图片

  rm: 无法删除 beinantest.txt: 权限不够
  那我们怎么才能让qiuyu 这个普通用户也拥有root超级的rm 删除功力呢?
  技术分享图片

  技术分享图片

  我们只是设置了rm的setuid位,让普通用户在rm指令上有超级root的删除超级权力
  通过这个例子,我们应该能明白setuid和setgid位的应用了,如同前面所说,让普通用户超越本身的能力,让普通用户能执行只有root才能 执行的命令在这一点,我们要和su和sudo 区分开来请参见su和sudo的文档:Linux 系统中的超级权限的控制

3、setuid和setgid的设置方法
  第一种方法:八进制方法
    setuid位是的设置用八进制的4000,setgid占用的是八进制的2000 ;比如我们前面所说的 chmod 4755 /bin/rm 就是设置的setuid位;
    至于setuid的设置方法,只是在我们通过chmod设置文件或目录权限位的八进制方法的前面多加一个数字,也就是4比如:
    技术分享图片

    作为setgid 位占用的是八进制的2000位,我们下面举个例子;
    技术分享图片

    我们看到 aa 这个目录,经过改变权限后的,目录所归属用户组的那三个权限位是 r-s 如果我们见到的是小写的s,表明文件所归属的用户组位有执行权限x因为我们用了2755 ,意思是说文件属主拥有可读可写可执行权限,所归属的用户组拥有可读可执行权限,并且设置了setgid,所以这时本来文件所归属的用户组拥有r-x,现 在加了setgid位,就把其中的x换成了s如果文件所归属的用户组没有执行权限,这个权限应该是S同理 setgid 位的中的大写的S和小写的s,也 是这个原理见下面的例子;
    技术分享图片

    这个例子是因为目录 aa 所归属的组没有执行权限,这时本来在执行权限位上显示-,由于有了setgid,所以显示为S
    如果我们为一个文件的权限拥有 属主可读可写可执行所归的组拥有可读可执行,其它用户可读可执行,并且同时设置setuid和setgid位,我们应该怎么运行命令呢?
    技术分享图片

    所以,同时设置setuid和setgid,就是把setuid和setgid两个八进位的值相加 (4000+2000=6000),然后加上文件或目录的权限位的三位数值(上面的例子是755),然后通过chmod 运行就行了所以上面例子中用了6755

  第二种方法:通过助记语法
    还是延用 chmod 的助记语法,通过 u+s 或 u-s  来增减setuid位,同理,我们可以通过 g+s 或 g-s 来setgid位;
    技术分享图片

    我们也可以用file命令来查看setuid和setgid位,当然也能用 file 来查看文件的类型:

    技术分享图片

Linux权限管理:setUID 和 setGID

原文:https://www.cnblogs.com/qiuyu666/p/11818730.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!