Linux-文件基本权限及特殊权限详解

Linux文件基本权限及特殊权限详解

背景

Linux文件基本权限和特殊权限对于初学者很少烦恼,各种无法理解,所以在学到这一节时,将自己学到的以及自己的理解写出来以检查自己对这个部分的掌握情况。

什么是权限

在Linux里一切皆文件,所谓的权限就是用户对文件(目录也是以个文件)的操作范围,对文件的操作包括读、写和执行,用户对文件有不同的权限就能做相应的操作。

目标

熟悉Linux文件的基本权限和特殊权限,明白文件权限后面对应的意义。

用户组

一个文件有对应三种用户:文件所有者、文件所属组、其他用户。每一种用户都对应着三种基本权限,包括读、写和执行。

所有者:谁创建这个文件就天然是这个文件的所有者,只有uid为0的用户(默认是root)可以使用chown命令来改变文件所有者。

Linux-文件基本权限及特殊权限详解

Linux-文件基本权限及特殊权限详解

所属组:一般情况下一个新建的文件的所属组就是创建者的主组。可以通过chgrp命令来改变文件的所属组。所属组中的成员会自动继承组的权限,即所属组有什么权限,成员就有什么权限,当然acl的用户除外。

Linux-文件基本权限及特殊权限详解

其他用户:包括除了所有者和所属组成员以外的其他用户。

文件基础权限

可以使用 ll 命令来查看文件的详细信息

Linux-文件基本权限及特殊权限详解

其中d:表示目录

      – :表示普通文件

      r:表示读权限

      w:表示写权限

      x:表示执行权限

  也可以用数字表示 r=4;w=2;x=1

  第一个rwx位:表示所有者权限

  第二个rwx位:表示所属组权限

  第三个rwx位:表示其他用户权限

文件权限的意义

对于不同的文件类型,文件的权限对应不同的意义。

普通文件的r权限表示拥有r权限的用户可以打开这个文件,w权限表示表示用户可以修改这个文件的内容,x表示用户可以执行这个文件。

而目录文件的rwx权限意义不同于普通文件。

1、目录文件的r权限表示用户可以列出目录里的文件但如果用户仅有r权限即400,则用户不可以cd到这个目录里不可用cat文件,不可以创建文件;能列出目录里的文件,但文件名字是乱码。

Linux-文件基本权限及特殊权限详解

2、w权限表示用户可以创建文件,但如果用户只有w权限即200,则用户不能cd到目录里,不能cat文件,不能创建文件,不能列出目录里的文件

Linux-文件基本权限及特殊权限详解

3、x权限表示用户可以进入到目录里,但如果只有x权限即100,目录里的文件不能列出,不能创建文件,可以cd进入目录,可cat有权限的文件。

Linux-文件基本权限及特殊权限详解

4、如果目录文件有r+x权限  即500,用户可以进入目录,列出文件,cat有权限的文件,但不能创建新文件

Linux-文件基本权限及特殊权限详解

5、如果目录权限为w+x即300,用户不能列出目录里的文件,可以进入目录,可创建文件,可cat有权限的文件

Linux-文件基本权限及特殊权限详解

6、如果目录文件的权限为r+w即600,则用户可以列出目录里的文件但是乱码,不能cd进目录,不能创建文件,不能cat文件

Linux-文件基本权限及特殊权限详解

当然这里只是列出了一中用户类型权限的使用,其他用户权限的也是一样的使用方式。

文件特殊权限

文件的特殊权限有三种包括suid(4)、sgid(2)、sticky(1);

suid 4    只能作用于二进制可执行程序上,当执行这个程序时会临时切换身份为文件所有者身份,典型的就是用户修改密码。

Linux-文件基本权限及特殊权限详解

可见这个文件所有权限都没有,但是我们可以使用passwd命令来修改这个文件。这是为什么呢?

那是因为/usr/bin/passwd文件有特殊权限s

Linux-文件基本权限及特殊权限详解

所有者有了s权限后,当用户执行这个程序时会临时将用户身份切换到root身份,而root用户是不受权限控制的,所以虽然没有任何权限,用户也可以修改密码。

这个权限很危险,比如如果cat有suid权限,则所有用户可以查看和修改所有文件。

sgid 2    作用于二进制可执行程序上,继承了此程序所属组的权限

Linux-文件基本权限及特殊权限详解

            作用于目录上,在该目录下新建文件所属组继承目录的所属组

Linux-文件基本权限及特殊权限详解

sticky 1 粘滞位     作用于目录,该目录下的文件只能被所有者和root删除,代表是/tmp目录

Linux-文件基本权限及特殊权限详解

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

(0)
657188918657188918
上一篇 2017-07-22
下一篇 2017-07-22

相关推荐

  • 第一周:Linux基础及哲学思想

    1.现代计算机的组成及功能    现代计算机由运算器、控制器、存储器、输入和输出设备5大部分组成。分别担当着计算机的计算,控制,存储,输入和输出等功能. 2.Linux的发行版及其之间的联系与区别     Linux发行版主要分支分为三大系列: Slackware、debian 、redhat  &…

    Linux干货 2016-06-23
  • CentOS启动流程

      我们介绍一下CentOS操作系统的详细启动流程,了解这些启动流程之后,我们可以实验做一个小型的Linux。 1、Linux的组成 2、Linux的运行环境 3、Linux的启动流程 3.1、POST加电自检 3.2、Boot Sequence(启动次序) 3.3、MBR 3.4、Kernel 3.5、init 1、Linux的组成 &…

    Linux干货 2016-12-04
  • LVM2:创建、使用、扩展、缩减、快照五步骤

    LVM2这是个关键的概念,还是从操作中比较容易理解 1、创建一个至少有两个PV组成的大小为40G的名为testvg的VG;要求PE大小为16MB, 而后在卷组中创建大小为5G的逻辑卷testlv;挂载至/users目录 注意点:在vmware中添加两块硬盘,但是并不能马上可以查看,需要扫描一下磁盘,磁盘未/dev/sdc,/dev/sdd 然后创建LVM的基…

    Linux干货 2016-09-05
  • 马哥网络班21期-第六周作业

    请详细总结vim编辑器的使用并完成以下练习题    vim(visual interface):文本编辑器      模式        编辑模式        输入模式        末行…

    Linux干货 2016-09-07
  • Linux基础之—用户和组管理

    导言:   我们在使用计算机资源时为了资源的合理规划和利用,同时为了实现更好的管理,需要在计算机里有一个使用资源的凭证,这个凭证就是用户,下面就来介绍Linux用户和组管理。 1.资源分派:     资源的分派可以分为三个步骤,分别是    (1)认证(Authertication)   &nbsp…

    Linux干货 2016-08-04
  • sed简介及常见用法

    sed是一个文本流处理器,配合正则表达式用可以实现很多文本处理操作。 和grep一样,sed是一行一行的处理的。sed处理文本时,首先会将源文件复制一份到内存中,然后将文本一行一行拿到模式空间内进行操作,最后输出到标准输出,即屏幕上。 在模式空间中,每一行都会根据用户给的条件进行匹配,匹配到了进行编辑后输出,没有匹配到,直接输出到标准输出。sed除了模式空间…

    2018-01-04