suid只有作用于文件上才起作用,suid只能作用于二进制可执行文件上 ,suid可以让执行该文件的用户临时以该文件属主身份去执行。
查看passwd权限
之前接触过更改密码用到的命令是:passwd
那么他在什么目录下呢,我们查看下
[root@evan-01 ~]# which passwd
/usr/bin/passwd
[root@evan-01 ~]# ls -l /usr/bin/passwd
-rwsr-xr-x. 1 root root 27832 Jun 10 2014 /usr/bin/passwd
[root@evan-01 ~]#
我们发现这个文件前面的权限里面有个s,这个 s 到底是什么含义呢?
rws
s 全称 (set_uid)
改密码的时候,我们实际更改的是 /etc/shadow,我们来查看下它
[root@evan-01 ~]# ls /etc/shadow
/etc/shadow
[root@evan-01 ~]# ls -l /etc/shadow
----------. 1 root root 641 Aug 9 10:24 /etc/shadow
[root@evan-01 ~]#
权限全是0,很严谨。Linux系统非常安全,作为root用户没有权限,那么怎么办呢?
set_uid 保证普通用户临时拥有该命令所有者身份
set_uid 保证普通用户临时拥有该命令所有者身份,前提文件得是二进制文件,并且得可执行
复制一个终端
切换到普通用户,使用ls命令,发现没有权限
再回到刚才的终端里,设置个临时权限,让它临时拥有root权限
[root@evan-01 ~]# chmod u+s /usr/bin/ls
[root@evan-01 ~]# ls -l /usr/bin/ls
-rwsr-xr-x. 1 root root 117656 Nov 6 2016 /usr/bin/ls
[root@evan-01 ~]#
再回到刚才复制的终端里面查看,发现已经可以使用ls命令了
other用户权限还是没有的,但是我们已经能查看了,因为ls有set_uid
取消权限
[root@evan-01 ~]# chmod u-s /usr/bin/ls
[root@evan-01 ~]# ls -l /usr/bin/ls
-rwxr-xr-x. 1 root root 117656 Nov 6 2016 /usr/bin/ls
[root@evan-01 ~]#
取消权限另外一种写法
[root@evan-01 ~]# chmod u=rws /usr/bin/ls
[root@evan-01 ~]# ls -l /usr/bin/ls
-rwSr-xr-x. 1 root root 117656 Nov 6 2016 /usr/bin/ls
[root@evan-01 ~]#
加上x权限,就变成小s了
[root@evan-01 ~]# chmod u+x /usr/bin/ls
[root@evan-01 ~]# ls -l /usr/bin/ls
-rwsr-xr-x. 1 root root 117656 Nov 6 2016 /usr/bin/ls
[root@evan-01 ~]#