【Linux】chmod/chown - Linux 文件/文件夹 权限

Posted by 西维蜀黍 on 2018-11-05, Last Modified on 2021-09-21

文件权限修改常用命令 - chmod

先上常用命令。

修改文件权限为可读可写可执行(777):

chmod 777 [文件或文件夹路径]

chmod 777 /var/home/userid/cc,此文件cc的权限就变为可读可写可执行(777)了。

修改文件夹及该文件夹内所有文件和子文件夹(包括子文件夹中的文件和文件夹)权限为可读可写可执行(777):

chmod -R 777 [文件或文件夹路径]

如可以看到test文件夹中包含2个文件和一个子文件夹(其中file2文件位于该子文件夹中):

使用 chmod -R 777 ./test后,这2个文件和这个子文件夹的权限都会变成可读可写可执行(777)。

chmod命令可用于改变文件或目录的访问权限。

该命令有两种用法。一种是包含字母和操作符表达式的文字设定法;另一种是包含数字的数字设定法。

权限设置之字母设定法

一个文件对于一个特定的用户,包含三种权限:读取(Read)、写入(Write)、执行(Execute)。这三种权限都分别用特定的字母表示:

  • **r(Read,读取):**对文件而言,具有读取文件内容的权限;对文件夹来说,具有浏览目录的权限
  • **w(Write,写入):**对文件而言,具有新增、修改文件内容的权限;对文件夹来说,具有删除该文件夹,且删除、移动文件夹内文件的权限
  • **x(eXecute,执行):**对文件而言,具有执行文件的权限;对文件夹来说,具有访问该文件夹的权限

通过ls -l [文件(夹)名],可以看到不同用户(组)对该文件的权限,比如:

具体来说,不同用户(组)又细分为文件所有者访问权限文件所有者所在群组访问权限其他用户访问权限。在@后的左边三个字母(--x)表示其他人访问权限对该文件的访问权限,接下来的三个字母(rw-)表示文件所有者所在群组访问权限,再接下来的三个字母(rwx)表示文件所有者访问权限

在上图中,除了当前用户所在组之外的其他用户对file1文件的访问权限为只可执行, 文件所有者所在组中所有用户对file1文件的访问权限为可读可写,当前用户对file1文件的访问权限为可读可写可执行

再比如,我们希望设置:文件所有者有“读”、“写”、“执行”权限,群组用户有“读”权限,其他用户有“读”权限,则对应的字母表示为rwx r– r–

语法

chmod [who] [+ | - | =] [mode] [文件名]
  • 操作对象who可是下述字母中的任一个或者它们的组合
    • u 表示“用户(user)”,即文件或目录的所有者
    • g 表示“同组(group)用户”,即与文件属主有相同组ID的所有用户
    • o 表示“其他(others)用户”
    • a 表示“所有(all)用户”。它是系统默认值
  • 操作符号可以是
    • 添加某个权限
    • 取消某个权限
    • = 赋予给定权限并取消其他所有权限(如果有的话)
  • 模式 mode (表示特定权限)可用下述字母的任意组合
    • r 可读
    • w 可写
    • x 可执行
  • 文件名:以空格分开的要改变权限的文件列表,支持通配符

示例

chmod a+x file1

设定文件file1的访问权限为:

  • 文件属主(u) 增加执行权限
  • 与文件属主同组用户(g) 增加执行权限
  • 其他用户(o) 增加执行权限
chmod ug+w,o-x text

设定文件file1的属性为:

  • 文件属主(u) 增加写权限
  • 与文件属主同组用户(g) 增加写权限
  • 其他用户(o) 删除执行权限

 

权限设置之数字设定法

除了用字母之外,你也可以用数字来表示权限分配。

比如,对于文章开头的777:777有3位,最左边的7表示设置文件所有者访问权限,第二位的7表示设置群组访问权限,最右边的7表示其他人访问权限。


同样地,一个文件对于一个特定的用户,包含三种权限:读取(Read)、写入(Write)、执行(Execute)。这三种权限都对应特定的权限值:

  • **r(Read,读取,权限值为4):**对文件而言,具有读取文件内容的权限;对文件夹来说,具有浏览目录的权限
  • **w(Write,写入,权限值为2):**对文件而言,具有新增、修改文件内容的权限;对文件夹来说,具有删除该文件夹,且删除、移动文件夹内文件的权限
  • **x(eXecute,执行,权限值为1):**对文件而言,具有执行文件的权限;对文件夹来说,具有访问该文件夹的权限

将三种权限对应的权限值相加得到的和,就是一个用户或用户组对特定文件的权限。比如:

  • 4+2+1=7,因此7表示该用户(组)对该文件具有读取、写入和执行的权限
  • 4+2=6,因此6表示该用户(组)对该文件具有读取和写入的权限
  • 1=1,因此1表示该用户(组)对该文件只具有执行权限

字母与数字的对应关系:

权限 数值
rwx rw- r– 764
rw- r– r– 644
rw- rw- r– 664

语法

chmod ([-R]) [权限对应的数值] [文件(夹)名]

添加-R参数可将一个文件夹下所有的文件和文件夹(包括子文件夹中的文件和文件夹)权限进行递归修改。

示例

chmod 644 file2

即设定文件mm.txt的属性为:-rw-r–r–

  • 文件属主(u)inin 拥有读、写权限
  • 与文件属主同组人用户(g) 拥有读权限
  • 其他人(o) 拥有读权限

chmod 750 file3

即设定wchtxt这个文件的属性为:-rwxr-x—

  • 文件主本人(u)inin 可读/可写/可执行权
  • 与文件主同组人(g) 可读/可执行权
  • 其他人(o) 没有任何权限

chmod 764 file1

表示:

  • 文件所有者对file1文件可读可写可执行
  • 文件所有者对应用户所在的组中的用户对file1文件可读可写
  • 其他用户对file1文件可读

更改文件或文件夹的拥有者 - chown

更改文件或文件夹的拥有者可以使用chown命令

chown [-R] [账户名称] [文件或目录]

Reference

https://blog.csdn.net/z4331016/article/details/79541051