权限管理:文件特殊权限—SetUID

1|0SetUID的功能


只有可以执行的二进制程序才能设定SUID权限
命令执行者要对该程序拥有x(执行)权限
命令执行者在执行程序时获得该程序文件属主的身份(在执行程序的过程中灵魂附体为文件的属主)
SetUID权限只在该程序执行过程中有效,也就是说身份改变只在程序执行过程中有效

passwd命令拥有SetUID权限,所以普通用户可以修改自己的密码(执行passwd实际写的是shadow文件,root用户可以对shadow文件读、写、执行)

[root@localhost chapter3]# ll /usr/bin/passwd -rwsr-xr-x. 1 root root 27856 Aug 9 2019 /usr/bin/passwd [root@localhost chapter3]# ll /etc/shadow ----------. 1 root root 660 Apr 25 15:36 /etc/shadow

cat命令没有SetUID权限,所以普通用户不能查看/etc/shadow文件内容

[root@localhost chapter3]# ll /bin/cat -rwxr-xr-x. 1 root root 54080 Aug 20 2019 /bin/cat

2|0设定SetUID的方法


chmod 4755 文件名 # 4代表SUID chmod u+s 文件名

给abc文件设置SetUID

[root@localhost chapter3]# touch abc [root@localhost chapter3]# ll abc -rw-r--r--. 1 root root 0 Jun 7 11:01 abc [root@localhost chapter3]# chmod 4755 abc [root@localhost chapter3]# ll abc -rwsr-xr-x. 1 root root 0 Jun 7 11:01 abc

如果文件没有可执行权限(644),那么显示的是S,S表示没有作用

[root@localhost chapter3]# touch ABC [root@localhost chapter3]# ll ABC -rw-r--r--. 1 root root 0 Jun 7 11:05 ABC [root@localhost chapter3]# chmod u+s ABC [root@localhost chapter3]# ll ABC -rwSr--r--. 1 root root 0 Jun 7 11:05 ABC

3|0取消SetUID的方法


chmod 755 文件名 chmod u-s 文件名

给abc文件取消SetUID

[root@localhost chapter3]# chmod 755 abc [root@localhost chapter3]# ll abc -rwxr-xr-x. 1 root root 0 Jun 7 11:01 abc

4|0危险的SetUID


关键目录应严格控制写权限,比如"/"、"/usr"等
用户的密码设置要严格遵守密码三原则
对系统中默认应该具有SetUID权限的文件做一列表,定时检查有没有这之外的文件被设置了SetUID权限
只要给vim赋予了SetUID权限,普通用户就可以使用vim修改所有系统文件,不光是用户密码文件,还有系统的启动文件,自动挂载文件等,所以这是很危险的


__EOF__

本文作者cnhkzyy
本文链接https://www.cnblogs.com/my_captain/p/13059928.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   cnhkzyy  阅读(432)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示