一、介绍
linux中“一切皆文件”。每个文件都设定了针对不同用户的访问权限。
文件权限主要针对以下三种对象:
属主:拥有者
属组:所属的组
其他人:不属于上述两类
二、文件权限
对于一个文件而言,操作它的用户可以分为三类:所有者,同组用户,其他用户
u:(user)表示文件属主的访问权限
g:(group)表示文件同组用户的访问权限
o:(others)表示其他用户的访问权限
(1)对于文件来说:
在创建的时候默认是有读和写的权限的,没有执行权限。
(2)对于目录来说:在创建的时候默认是有读写和执行的权限的。
三、修改文件权限
想要改文件的权限,只有管理员root和所有者才能修改
使用chmod命令可以改变文件或目录的权限,命令格式:chmod [选项] 文件
Linux文件属性有两种设置方法,一种是数字,一种是符号。
(1)数字修改法:
我们可以使用数字来代表各个权限,各权限的分数对照表如下:
r:4
w:2
x:1
每个身份的权限是需要累计相加的,
例如 使用数字法将文件权限修改为: 拥有者: 可读可写可执行/用户组:可读可写/其他用户:可写可执行
分析:拥有者:rwx -->4+2+1=7
用户组:rw- -->4+2=6
其他用户:wx -->2+1=3
因此要执行的修改命令为:chmod 763 aa 如下图:
(2)字母修改法:
字母修改法就是使用u,g,o来代表三种身份的权限
其中a可以代表所有身份
+表示增加权限 -表示去掉权限 =代表赋予权限
例如:使用字母法将文件权限修改为: 拥有者: 可读/用户组: 可写/其他用户:可执行
分析:假设文件权限都为初始创建的可读可写
拥有者u:r
用户组g:w
其他用户o:x
因此要执行的修改命令为:chmod u-w,g-r,o=x aa 如图:
注意:在修改权限时,多个身份权限之间用","隔开,而且不能有空格!
再比如:使用字母法将文件权限修改为:每种用户都可以做写操作
分析:假设文件权限为初始创建权限
我们可以使用a来表示所有用户身份
因此要执行的修改命令为:chmod a+w aa 如图:
拓展:
1、chgrp:是change group的缩写,在Linux中 chgrp 命令可以变更文件与目录所属群组,设置方式采用群组名称或群组识别码都可以,
但是要被改变的组名必须要在/etc/group文件内存在才行
语法:chgrp [选项] [组] [文件]
实例:改变文件的群组属性:将log1.txt文件由root群组改为bin群组 。
2、chown:chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户ID;组可以是组名或者组ID;
文件是以空格分开的要改变权限的文件列表,支持通配符。系统管理员经常使用chown命令,在将文件拷贝到另一个用户的名录下之后,让用户拥有使用该文件的权限。
语法:chown [-cfhvR] [--help] [--version] user[:group] file...