文件权限除了r、w、x外还有s、t、i、a权限:

首先我们利用umask查看系统的权限为四位,首位就是特殊权限位,SetUID为4,SetGID为2,t为1

[root@iz2ze46xi6pjjj69ailg9lz ~]# umask

一、 s权限解读:  (SetUID和SetGID)

1.SetUID权限解读(针对所属主设置s权限,数字表示为4)

  SetUID:当一个可执行程序具有SetUID权限,用户执行这个程序时,将以这个程序所有者的身份执行。前提是这个文件是可执行文件,可就是具有x权限(属组必须先设置相应的x权限)。chmod命令不进行必要的完整性检查,即使不设置x权限就设置s权限,chmod也不会报错,当我们ls -l时看到rwS,大写S说明s权限未生效)

  •   (1)设置权限的方法:

          chmod u+s xxx

         chmod 4777 xxx

    解释:我们利用umask知道权限的设置是四位数,后三位是ugo对应的属性,首位就是特殊位权限的表示,SetUID的权限位是4,因此可以用chmod 4777 xxx设置s权限。

  例1: linux的passwd命令就具有s权限,因此普通用户可以修改自己的密码:

[qlq@iz2ze46xi6pjjj69ailg9lz ~]$ ls -la `which passwd`
-rwsr-xr-x. root root Jun /usr/bin/passwd

    解释:passwd的所属这是root,所属组也是root,具有s权限,因此其他用户执行passwd的时候是以passwd的所属组root执行。

  例2:将touch赋予s权限,查看其创建的文件的所属组

    (1)qlq用户touch没有被赋予s权限的时候创建一个文件(所属主是当前用户,所属组是当前用户的组:)

[qlq@iz2ze46xi6pjjj69ailg9lz test]$ ls
[qlq@iz2ze46xi6pjjj69ailg9lz test]$ touch test1file
[qlq@iz2ze46xi6pjjj69ailg9lz test]$ ll
total
-rw-rw-r-- qlq qlq Mar : test1file

    (2)root用户将touch赋予s权限:

[root@iz2ze46xi6pjjj69ailg9lz ~]# chmod u+s `which touch`  #赋予所属主s权限
[root@iz2ze46xi6pjjj69ailg9lz ~]# ll `which touch`    #查看touch权限
-rwsr-xr-x. root root Nov /usr/bin/touch

    (3)qlq用户再次创建一个文件查看所属主(所属主是root,所属组是当前用户所属组)

[qlq@iz2ze46xi6pjjj69ailg9lz test]$ touch test1file2
[qlq@iz2ze46xi6pjjj69ailg9lz test]$ ll ./test1file2
-rw-rw-r-- root qlq Mar : ./test1file2
  • (2)收回s权限

chmod u-s xxx

    chmod  0777   xxx

例如:收回上面的touch的s权限之后再次创建文件:

    (1)root用户收回权限

[root@iz2ze46xi6pjjj69ailg9lz ~]# chmod  `which touch`    #收回权限
[root@iz2ze46xi6pjjj69ailg9lz ~]# ll `which touch`      #查看权限
-rwxr-xr-x. root root Nov /usr/bin/touch

      第一位为特殊权限位。因此用0就表示没有特殊权限。

    (2)qlq用户再次创建一个文件查看信息:(所属主变成当前用户)

[qlq@iz2ze46xi6pjjj69ailg9lz test]$ ll ./test1file3
-rw-rw-r-- qlq qlq Mar : ./test1file3
  • (3)查看系统具有SetUID或者GID的文件
[root@iz2ze46xi6pjjj69ailg9lz ~]# find / -perm 4755 -o -perm 2755  #跟据权限查看,-o表示or,4代表SetUID,2代表SetGID
/usr/lib/polkit-/polkit-agent-helper-
/usr/sbin/netreport
/usr/sbin/postqueue
/usr/sbin/pam_timestamp_check
/usr/sbin/unix_chkpwd
/usr/sbin/postdrop
/usr/sbin/usernetctl
/usr/bin/at
/usr/bin/gpasswd
/usr/bin/passwd
/usr/bin/write
/usr/bin/su

注意:

  vim和vi不能被授予s权限,否则好多只读文件都可以被以root身份保存。

  • (4)当我们针对一个不具备x权限的文件设置s权限时无效,权限变为大写S,大写S说明s权限未生效
[qlq@iz2ze46xi6pjjj69ailg9lz test]$ chmod u+s ./test1file
[qlq@iz2ze46xi6pjjj69ailg9lz test]$ ll
total
-rwSrw-r-- qlq qlq Mar : test1file

2.SetGID解读(针对所属组设置权限,数字表示为2)

  一个可执行文件具有SetGID权限表示运行这个程序的时候是以这个程序的所属组的身份运行,同样这个文件需要具有x权限(必须可以运行)

设置权限方法

  chmod g+s xxx

  chmod 2777 xxx

收回权限方法:

  chmod g-s xxx

  chmod 0777 xxx

例1:针对上面的touch同时设置SetUID和SetGID权限之后创建文件

(1)root用户设置权限

[root@iz2ze46xi6pjjj69ailg9lz ~]# chmod  `which touch`
[root@iz2ze46xi6pjjj69ailg9lz ~]# ll `which touch`
-rwsr-sr-x. root root Nov /usr/bin/touch

(2)qlq用户创建一个文件:(所属主为root,所属组是root所在的组)

[qlq@iz2ze46xi6pjjj69ailg9lz test]$ touch test1file4
[qlq@iz2ze46xi6pjjj69ailg9lz test]$ ll | grep test1file4
-rw-rw-r-- root root Mar : test1file4

例2:将touch的权限只设置SetGID并创建文件:

(1)root用户设置权限

[root@iz2ze46xi6pjjj69ailg9lz ~]# chmod  `which touch`
[root@iz2ze46xi6pjjj69ailg9lz ~]# ll `which touch`
-rwxr-sr-x. root root Nov /usr/bin/touch

(2)qlq用户创建一个文件:(所属主为qlq,所属组是root所在的组)

[qlq@iz2ze46xi6pjjj69ailg9lz test]$ touch test1file5
[qlq@iz2ze46xi6pjjj69ailg9lz test]$ ll | grep test1file5
-rw-rw-r-- qlq root Mar : test1file5

例三:收回touch的SetGID权限:

[root@iz2ze46xi6pjjj69ailg9lz ~]# chmod g-s `which touch`
[root@iz2ze46xi6pjjj69ailg9lz ~]# ll `which touch`
-rwxr-xr-x. root root Nov /usr/bin/touch

注意:上面的SID和GID要求用户必须有执行文件的权利,如果有执行权限执行的时候s位才会生效:

例如:

(1)root将o的x权限去掉

[root@iz2ze46xi6pjjj69ailg9lz ~]# chmod  `which touch`
[root@iz2ze46xi6pjjj69ailg9lz ~]# ll `which touch`
-rwsr-x---. root root Nov /usr/bin/touch

(2)qlq执行touch命令权限不允许:

[qlq@iz2ze46xi6pjjj69ailg9lz ~]$ touch www
-bash: /usr/bin/touch: Permission denied

二、黏着位 t  解读(针对others设置,可以实现文件夹共享)

t :设置粘着位,一般针对权限是777的文件夹设置权限。如果文件设置了t权限则只有属主和root有删除文件的权限(没有意义)

  如果权限为777的目录设置t权限,索引用户可以在这个目录下面创建文件和删除自己创建的文件,删除其他人创建的文件权限不被允许(当然root可以删除所有人创建的权限)。(为了共享目录,例如临时文件夹)

设置权限

  chmod  o+t  xxx

  chmod  1777 xxx

收回权限

  chmod o-t  xxx  

  chmod 0777 xxx

例1:linux的存放临时文件夹的tmp目录就有t权限:

[root@iz2ze46xi6pjjj69ailg9lz /]# ll / | grep tmp
drwxrwxrwt. root root Mar : tmp

例2:创建一目录并设置t权限:

(1)root用户创建目录并设置权限为777+t权限

[root@iz2ze46xi6pjjj69ailg9lz test]# chmod  /mydir/
[root@iz2ze46xi6pjjj69ailg9lz test]# ll /|grep mydir
drwxrwxrwx root root Mar : mydir
[root@iz2ze46xi6pjjj69ailg9lz test]# chmod o+t /mydir/
[root@iz2ze46xi6pjjj69ailg9lz test]# ll /|grep mydir
drwxrwxrwt root root Mar : mydir

(2)root用户在此目录下创建几个文件

[root@iz2ze46xi6pjjj69ailg9lz mydir]# touch rootfle1
[root@iz2ze46xi6pjjj69ailg9lz mydir]# touch rootfle2
[root@iz2ze46xi6pjjj69ailg9lz mydir]# ll
total
-rw-r--r-- root root Mar : rootfle1
-rw-r--r-- root root Mar : rootfle2

(3)qlq在此目录下创建文件并删除文件(可以创建文件与删除自己创建的文件,删除root创建的文件被提示不允许)

[qlq@iz2ze46xi6pjjj69ailg9lz /]$ cd /mydir/
[qlq@iz2ze46xi6pjjj69ailg9lz mydir]$ touch qlqfile1
[qlq@iz2ze46xi6pjjj69ailg9lz mydir]$ touch qlqfile2
[qlq@iz2ze46xi6pjjj69ailg9lz mydir]$ rm rootfle1
rm: remove write-protected regular empty file ‘rootfle1’? y
rm: cannot remove ‘rootfle1’: Operation not permitted
[qlq@iz2ze46xi6pjjj69ailg9lz mydir]$ rm -f qlqfile1
[qlq@iz2ze46xi6pjjj69ailg9lz mydir]$ ll
total
-rw-rw-r-- qlq qlq Mar : qlqfile2
-rw-r--r-- root root Mar : rootfle1
-rw-r--r-- root root Mar : rootfle2

三、i与a权限解读

  参考:http://www.cnblogs.com/qlqwjy/p/8358917.html

i:不可修改权限  例:chattr u+i filename 则filename文件就不可修改,无论任何人,如果需要修改需要先删除i权限,用chattr -i filename就可以了。查看文件是否设置了i权限用lsattr filename。

a:只追加权限, 对于日志系统很好用,这个权限让目标文件只能追加,不能删除,而且不能通过编辑器追加。可以使用chattr +a设置追加权限。

关于Linux下s、t、i、a权限的更多相关文章

  1. Linux下ls命令显示符号链接权限为777的探索

    Linux下ls命令显示符号链接权限为777的探索 --深入ls.链接.文件系统与权限 一.摘要 ls是Linux和Unix下最常使用的命令之一,主要用来列举目录下的文件信息,-l参数允许查看当前目录 ...

  2. Linux 下指定端口开放访问权限

    Linux 下指定端口开放访问权限 作者:Grey 原文地址: 博客园:Linux 下指定端口开放访问权限 CSDN:Linux 下指定端口开放访问权限 环境 CentOS 系和 Debian 系的防 ...

  3. Linux下报 java.net.SocketException权限不够 异常解决

    转载自:http://wangchongan.com/articles/java-net-socket-exception-permission-denied.html 今天在Linux下用Jetty ...

  4. Linux下的文件与目录权限

    一.用户(User).群组(Group)和其他人(Others) linux是多用户多任务的操作系统,同一时刻可能会有多个用户登录系统,考虑到文件的安全性等问题,所以Linux下的文件都属于一个特定的 ...

  5. Linux 下添加用户,修改权限

    最近在用虚拟机,安装了centos,现在想新添加一个用户,在网上找了找方法.[原文链接] # useradd –d /usr/sam -m sam 此命令创建了一个用户sam,其中-d和-m选项用来为 ...

  6. Linux下mysql新建账号及权限设置各种方式总结

    来自:http://justcoding.iteye.com/blog/1941116 1.权限赋予 说明:mysql部署在服务器A上,内网上主机B通过客户端工具连接服务器A以进行数据库操作,需要服务 ...

  7. linux下创建文件的文件权限问题

    今天发现创建文件的权限和自己规定的权限不一致,了解到了权限掩码的问题,这里总结一下. 首先权限掩码umask是chmod配套的,总共为4位(gid/uid,属主,组权,其它用户的权限),不过通常我们都 ...

  8. (转)Linux 下 查看以及修改文件权限

    场景:Linux环境下远程部署项目,发现因为文件权限问题,不能执行远端的可执行文件.问题还没解决,待议... 1 查看权限 在终端输入: ls -l xxx.xxx (xxx.xxx是文件名) 那么就 ...

  9. Linux下SVN部署/安全及权限配置,实现web同步更新

    转自:http://www.cnblogs.com/me115/archive/2013/04/07/3002058.html 本文包含以下内容: SVN服务器安装 SVN权限管理 SVN使用SASL ...

  10. linux 下如何给用户添加权限

    linux 添加用户.权限:# useradd –d /usr/sam -m sam此命令创建了一个用户sam,其中-d和-m选项用来为登录名sam产生一个主目录/usr/sam(/usr为默认的用户 ...

随机推荐

  1. Delphi Code Editor 之 快捷菜单

    Code Editor的快捷菜单分为两个部分:编辑器菜单项和调试器菜单项. 调试器菜单项留作以后讲解调试应用程序时再讲,这里只讲讲Code Editor的编辑器快捷菜单项. 下面列出了全部菜单项及描述 ...

  2. Bootstrap排版类

    类 描述 实例 .lead 使段落突出显示 尝试一下 .small 设定小文本 (设置为父文本的 85% 大小) 尝试一下 .text-left 设定文本左对齐 尝试一下 .text-center 设 ...

  3. C#多线程间的同步问题

    使用线程时最头痛的就是共享资源的同步问题,处理不好会得到错误的结果,C#处理共享资源有以下几种: 1.lock锁 需要注意的地方: 1).lock不能锁定空值某一对象可以指向Null,但Null是不需 ...

  4. RT-thread国产实时操作系统概述

    RT-Thread实时操作系统是一个分层的操作系统,它包括了: • 组件层components,这些是基于RT-Thread核心基础上的外围组件,把一些功能模块划分成独立的一个个组件模块,做到组件与组 ...

  5. Xcode开发技巧之code snippets(代码片段)

    一.什么是代码片段 当在Xcode中输入dowhile并回车后,Xcode会出现下图所示的提示代码: 这就是代码片段,目的是使程序员以最快的速度输入常用的代码片段,提高编程效率.该功能是从Xcode4 ...

  6. BZOJ4299 Codechef FRBSUM(主席树)

    感觉非常不可做,于是考虑有什么奇怪的性质. 先考虑怎么求子集和mex.将数从小到大排序,假设已经凑出了0~n的所有数,如果下一个数>n+1显然mex就是n+1了,否则若其为x则可以凑出1~n+x ...

  7. 深入理解Delete(JavaScript)

    深入理解Delete(JavaScript) Delete  众所周知是删除对象中的属性. 但如果不深入了解delete的真正使用在项目中会出现非常严重的问题 (: Following 是翻译  ka ...

  8. 【Codeforces Round #406 (Div. 2)】题解

    The Monster 签到题,算一下b+=a和d+=c,然后卡一下次数就可以了. Not Afraid 只要一组出现一对相反数就是安全的. Berzerk 题意:[1,n],两个人轮流走,谁能走到1 ...

  9. 项目管理---git----快速使用git笔记(七)------coding.net项目管理多人操作的流程规范--合并代码审核

    我们在前面已经介绍了coding.net和本地git的基本用法. 但是多人协作开发时情况会复杂得多,所以我们最好有一些规范来保证项目多人开发顺利进行. 比如说 规范一 master代码分支  需要开启 ...

  10. Consul入门

    推荐: Consul 原理和使用简介 启动:consul agent -server -bootstrap-expect 1 -data-dir /tmp/consul -node Litao-Mac ...