linux系统上的特殊权限SUID,SGID,STICKY

特殊权限:SUID SGID STICKY

    linux的安全上下文:

    1.进程以用户的身份运行,进程是发起此用户的代理,因此以此用户的身份和权限完成所有的操作。

    2.权限匹配模型:

    1)判断进程的属主,是否以被访问的文件属主。如果是,则应用属主权限,否则进入第2步。

    2)判断进程的属主,是否属于被访问的文件属组。如果是,则应用属组的权限,否则进入第3步。

    3)应用other的权限。


SUID:

    默认情况下,用户发起的进程,进程的属主是其发起者,因此,其以发起者的身份在运行。

    SUID的功用:用户运行某程序时,如果此程序拥有SUID权限,那么程序运行时,进程的属主不是发起者,而是程序文件自己的属主。


管理文件的SUID权限:

    chmod u+|-s FILE

    展示位置:属主的执行权限位

             如果属主本有执行权限,显示为小写s,

             否则,显示为大写S。


[root@localhost ~]# cp /bin/cat /tmp/jackfile1      #将cat命令拷贝为jackfile1


[root@localhost ~]# mv /bin/cat /bin/cat.txt        #把cat路径重新编辑,使系统找不到cat命令


[root@localhost tmp]# chmod u+s jackfile1           #增加jackfile1特殊权限suid


[root@localhost tmp]# ll jackfile1                  #查看jackfile1的属主属组和权限

-rwsr-xr-x. 1 jack jack 48568 Aug  1 19:11 jackfile1


[jack@localhost jack]$ ll 2.txt         #jack用户新建2.txt文件,jack5用户对此文件无任何权限

-rw-rw—-. 1 jack jack 52 Aug  1 19:25 2.txt


[jack5@localhost jack]$ /tmp/jackfile1 2.txt    #使用jack5用户查看jack用户所建的2.txt文件

agjjfjskdfjlsdfjlsfjsldjgljgljlajgljhljlkdahljfsdjk


实验结论:以上试验中,把jackfile1变成cat命令使用,当jackfile1具有s权限时,其他用户使用jackfile1命令,就相当拥有jackfile1的属主权限,所以任何jack所建的文件,其他用户都可以进行访问。

            


SGID:

    功用:当目录属组有写权限,且有SGID权限时,那么所有属于此目录的属组,且以属组的身份在此目录中新建文件或者目录时,新文件的属组不是用户的基本组,而是此目录的属组。


管理文件的SGID权限:

    chmod g+|-s FILE

    展示位置:属组的执行权限位

             如果属组原本有执行权限,显示为小写s

             否则,显示为大写S


[jack@localhost jack]$ ll -d                   #设定文件目录jack有SGID权限

drwxrwsr-x. 2 jack jack 4096 Aug  1 19:25 .


[jack3@localhost jack]$ id jack3               #设定jack组为jack3的附加组

uid=4019(jack3) gid=4019(jack3) groups=4019(jack3),4023(jack)


[jack3@localhost jack]$ touch 5.txt           #使用jack3用户新建5.txt文件

 

[jack3@localhost jack]$ ll                 #查看5.txt文件的所属组是jack,而不是主要组jack3

-rw-rw-r–. 1 jack3 jack  0 Aug  1 19:39 5.txt


实验结论:

1.需要jack3用户有jack的附加组。(如果其他用户有写权限,所建文件也是jack组)

2.由于加入SGID权限,用户所建文件的组为jack,意味着jack组内任何成员都可以对5.txt文件进行读写操作。


SGID还有一种用法类似SUID:

[root@localhost ~]# ll /bin/cat                          #给cat设置sgid

-rwxr-sr-x. 1 root root 48568 May 11 16:59 /bin/cat


[root@localhost ~]# ll /etc/shadow                       #给shadow设置有root组有读权限

—-rwx—. 1 root root 2899 Aug  2 14:51 /etc/shadow 


[jack5@localhost ~]$ cat /etc/shadow                     #随便使用一个用户借用root组的权限

root:$6$zNiiCr8zbAa2xFVa$4Tw89HFHnREnLhhyK2Z/E.w4WlUEIgXR2RaY5bYPu1/f.A3QJF8mcFNaz4EnB7LAUQ/KXWYieQ2cZwhdnTV981:17001:0:99999:7:::

bin:*:15980:0:99999:7:::




STICKY:

    功用:对于属组或全局可写的目录,组内的所有用户或系统上的所有用户对在此目录中都能创建新文件或删除所有的已有文件,如果为此类目录设置sticky权限,则每个用户都能创建新文件,且只能删除自己的文件。

    

管理文件的sticky权限:

    chmod o+|-t FILE

    展示位置:其它用户的执行限位

            如果其它用户原本有执行权限,显示为小写t

            否则,显示为大写T

   系统上的/tmp和/var/tmp目录默认均有sticky权限


[jack@localhost jack]$ ll -d                 #设置jack目录拥有sticky权限,注意看t

drwxrwxrwt. 2 jack jack 4096 Aug  1 20:04 .


[jack4@localhost ~]$ id jack4                #用户jack4为普通用户,跟jack无任何关系

uid=4020(jack4) gid=4023(jack) groups=4023(jack)


[jack4@localhost jack]$ touch 4.txt          #jack4用户在jack目录里建文件4.txt 


[jack3@localhost jack]$ rm 4.txt      #使用另一jack3账户对jack4所建文件4.txt进行删除,失败

rm: remove write-protected regular empty file `4.txt'? Y

rm: cannot remove `4.txt': Operation not permitted

     

实验结论:

1.用户在拥有t权限目录中所建文件,其他用户只能互相修改查看,无法删除其他人所建文件,只能自己删除自己的文件。

2.建立t权限目录的用户有权限删除该目录下的任何文件。

原创文章,作者:zebra930,如若转载,请注明出处:http://www.178linux.com/27626

(0)
zebra930zebra930
上一篇 2016-08-05 16:18
下一篇 2016-08-05 16:20

相关推荐

  • Apache配置压缩优化时报错——undefined symbol: inflateEnd

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1345264    圣诞都过了,好久没来51发博文了。最近一直在忙考试和其他一些私人事务,感觉长期不发博文,有点不好。不是不发,实在是最近…

    Linux干货 2016-08-15
  • 正则表达式简述

    正则表达式简述 什么是正则表达式: 正则表达式,又称正规表示法、常规表示法(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。 正则表达式分类: 标准正…

    Linux干货 2016-04-05
  • 重构-改善既有代码的设计:重构原则(二)

    1.什么是重构 重构(Refactoring):在不改变软件的功能和外部可见性的情况下,为了改善软件的结构,提高清晰性、可扩展性和可重用性而对软件进行的改造,对代码内部的结构进行优化。 2.为何重构   1)改进软件设计(整理代码) 重构和设计是相辅相成的,它和设计彼此互补。有了重构,你仍然必须做预先的设计,但是不必是最优的设计,只需要一个合理的解…

    Linux干货 2015-04-07
  • ansible基础应用

    ansible基础 一、运维主要工作 ansible聚集以上功能于一身,能够完整轻易的实现应用部署和批量命令功能,适用于主机数量不太多,再大的用puppet。 二、ansible特性 (1)模块化:调用特定的模块,完成特定任务; (2)基于python语言实现,由paramiko,PYYAML和JINJa2三个关键模块组成 (3)部署简单:agentless…

    Linux干货 2017-01-04
  • yum 仓库

    Yum 仓库     yum源就是一个软件集合地,你只需要搜索并安装你想要的软件,它会帮你解决大部分软件的依赖问题。本地源比如说光盘里面一般会附带一些软件,这个时候就可以把光盘当成本地源来安装软件。网络源比如说aliyun的镜像网站,这就属于网络源,可以通过互联网把软件下载下来并安装。   yum 仓库 &n…

    2017-06-24
  • 第四周:/etc/passwd、/etc/group文件熟悉及配合grep使用正则表达式

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@wlm ~]# useradd tuser1 [root@wlm ~]# cp -r etc/skel/ /home/tuser1/…

    Linux干货 2016-10-13