第 8.4 节 用户权限
FreeBSD 文件访问权限可以用 10 个标志位来说明,10 个标志位由 4 部分组成:
第一部分是第 1 位,用 d 表示目录,- 表示普通文件,l 表示链接,b 表示块设备文件,p 表示管道文件,c 表示字符设备文件,s 表示套接字文件;
第二部分是第 2-4 位,用于标识文件所属用户对文件的访问权限,用 rwx
表示读、写、 执行权限,无权限就写成 -
;
第三部分是第 5-7 位,用于标识文件所属组成员对文件的访问权限,标识参考第二部分。
第四部分是第 8-10 位,用于标识文件其他用户对文件的访问权限,标识参考第二部分。
读、写、执行除了用 rwx
表示,也可以对应成数字 4、2、1,没有权限用 0,每部分的 数字相加后,组合在一起,就是 3 位数字的表示方式。
如:
字符标识权限 | 数字标识权限 | 说明 |
---|---|---|
-rwxrwxrwx | 777 | 所有人都可读、写、执行的普通文件 |
drw------- | 600 | 这是一个目录,只有所属用户可以读、写 |
-rwxr-xr-x | 755 | 普通文件,所属用户有读、写、执行权限,同组用户和其他用户只能读取或执行,不可写入 |
- ls 命令,列出文件,常用参数:
-l
,列表显示文件信息,信息中包含权限、属主、文件大小、修改日期和时间等信息,也可以直接用 ll 命令
-a
,隐藏文件也要显示
示例:
# ls -l -a #列表显示包括隐藏文件在内的所有文件
# ll -a #与上例效果相同
# ls -l /tmp/a.log #列表显示 /tmp/a.log 文件
- chmod 命令,修改文件访问权限,有两种操作方式。
一种是操作符方式,如:
# chmod a+x t.sh
在“a+x”中:
第一位表示操作对象,u
是所属用户,g
是所属组,o
是其他用户,a
则表示所有用户,不写按系统默认操作;
第二位是操作符,+
是添加权限,-
是去除权限;
第三位是权限模式,rwx
分别表示读、写、执行,还有 s
表示文件执行时把进程属主或组置成与文件属主或组一致,这种方式使用起来比较直观。
另一种是数字方式,如: chmod 750 t.sh
其中 7 表示所属用户拥有读、写、执行的权限,同组用户有读和执行的权限,其他用户则没有任何权限,这种方式使用起来比较方便。
然后 chmod
还有一个重要的参数:
-R
,递归赋权
示例:
# chmod -R 777 /tmp #/tmp 目录下所有文件将允许任何用户读、写、执行
# chmod -R a+rwx /tmp #/tmp 目录下所有文件将允许任何用户读、写、执行
3.chown
命令,修改文件的属主,包括所属用户和所属组。
常用参数:
-R
,递归赋权
示例:
# chown test1 t.sh #修改 t.sh 属主为用户 test1
# chown test1:test t.sh #修改 t.sh 属主为用户 test1、组 test
# chown -R test1:test /tmp #修改/tmp 目录下所有文件的属主为用户 test1、组 test