今天继续给大家介绍Linux基本知识,本文主要内容是介绍Linux文件权限相关命令。
一、chown命令修改文件属主
在Linux系统中,chown命令可以更改文件的属主和属组,chown命令使用示例如下:
chown user.user target
chown user:user target
上述命令效果等价,都是将target文件的属主和属组改成user用户。chown命令执行如下所示:
如果chown命令的对象是一个目录,则如果想要只更改这个目录自身的属主和属组,可以直接按照上述命令执行,但是如果想要更改这个文件夹下面的所有文件和子文件夹,则需要加上-R参数,表示递归修改。
如果想要只修改文件的属组,则可以执行如下命令:
或者使用chgrp命令,
二、chmod命令修改文件权限
在Linux系统中,chmod命令可以修改文件的权限。chmod修改文件权限由两种方式,一种是数字方式,另一种是表达式方式。
如果采用数字方式,则需要将Linux的读、写、执行权限分别按照4、2、1的数字计算出属主、属组和其他用户的权限,这样就可以得到三个数字,比如如果属主的权限是允许读、写和执行,属组的权利是允许读和写,其他用户的权限是允许读,则我们可以把这样的权利写作数字表达式764。
在学会了数字表达式之后,我们就可以利用数字表达式对文件进行授权了,示例如下:
chown命令也可以给文件授予特殊权限,此时的数字表达式会有四位,其中第一位表示特殊权限,特殊权限SUID、SGID和SBIT分别表示4、2、1,使用示例如下:
在使用chown给文件授予特殊权限时,一定要注意:
如果chown的对象是目录,则不能够通过命令:
chmod 0000 target
撤销掉指定目录的SUID和SGID权限,如下所示:
如果想要撤销目录的特殊权限,则必须使用表达式的方式。
如果采用表达式方式,则chown采用以下命令 格式:
chown [身份]{+,-,=}[权限] [目标文件]
属主、属组和其他用户分别使用u、g和o表示,读、写和执行权限分别采用r、w和x表示,因此采用表达式的方式,chown命令如下所示:
chown u+r target
chown u=rw target
chown o-w target
chown u= target
上述四条命令分别表示对于target文件,属主添加读的权利,属主的权利修改为读和写,其他用户删除写的权利,属主没有任何权限。
如果想要使用表达式的方式对特殊权限进行操作,则操作如下:
u和s组合表示SUID权限
g和s组合表示SGID权限
o和t表示SBIT权限
如果u、g和o在执行命令前拥有执行的权限,则s和t应当小写,如果没有执行的权限,则s和t应该大写。(在实际操作中,也可以先随便选择大写,如果大写执行失败执行小写)
chown对文件的特殊权限进行操作示例如下:
chown u+S target
chown o-t target
上述命令依次表示对于target文件,增加SUID权限和删除SBIT权限。
使用表达式方式彻底删除文件特殊权限如下所示:
原创不易,转载请说明出处:https://blog.csdn.net/weixin_40228200/article/details/120601658