Linux

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > Linux > Linux中chmod权限设置

Linux中chmod权限设置方式

作者:likeyou~coucou

本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活地控制文件和目录的访问权限

设置基本权限命令:chmod

1、权限介绍

Linux中,文件和目录的权限由三个部分构成:所有者(user)、所属组(group)和其他用户(others)。

每个用户组有读取(r)、写入(w)和执行(x)的权限。文件和目录的权限可以使用 ls -l 命令查看。

chmod命令语法:

chmod [选项] [模式] 文件或目录

在 Linux 中,可以使用以下命令设置文件或目录的权限:

2、chmod命令常见用法和示例

数字模式(八进制):

使用数字来表示权限,每个权限用三位数字表示。其中,每一位的含义如下:

将所有者、所属组和其他用户的权限分别加起来,形成一个三位数。

符号模式:

使用符号来表示权限的增加或减少。符号模式包括以下符号:

可以结合以下字符来表示权限:

符号模式的简略写法:

3、文件权限详解

以下是ls -l 输出定义:

root@VM-12-3-ubuntu:~# ls -l 1.txt
-rw-r--r-- 1 root root 0 Jan 29 14:27 1.txt
root@VM-12-3-ubuntu:~#


第一个字符 - 表示这是一个普通文件。
rw- 表示所有者(root)具有读写权限。
r-- 表示所属组(root)具有读权限。
r-- 表示其他人具有读权限。
1: 这是链接数,表示指向该文件的硬链接数量。

root: 这是所有者的用户名。

root: 这是所属组的组名。

0: 这是文件的大小(以字节为单位)。

Jan 29 14:27: 这是文件的最后修改日期。

1.txt: 这是文件的名称。

如果使用普通用户去编辑这个文件,则会显示权限不足,如下

[root@test1 ~]# touch test.txt
[root@test1 ~]# ls -l test.txt
-rw-r--r--. 1 root root 0 Jan 19 09:49 test.txt
[root@test1 ~]# chmod ugo+r test.txt
[root@test1 ~]# ls -l test.txt
-rw-r--r--. 1 root root 0 Jan 19 09:49 test.txt
[root@test1 ~]# chmod u+rwx test.txt
[root@test1 ~]# ls -l test.txt
-rwxr--r--. 1 root root 0 Jan 19 09:49 test.txt
[root@test1 ~]#

4、chmod通过字符添加权限

以下是常用的字符表示法:

在这些字母之前,你可以使用以下字母中的一个来指定要添加权限的用户组:

例如:

4.1、将文件1.txt的所有者和所属组添加执行权限,如下权限前后变化

root@VM-12-3-ubuntu:~# ls -l 1.txt
-rw-r--r-- 1 root root 0 Jan 29 14:27 1.txt
root@VM-12-3-ubuntu:~# chmod u+x,g+x 1.txt
root@VM-12-3-ubuntu:~# ls -l 1.txt
-rwxr-xr-- 1 root root 0 Jan 29 14:27 1.txt
root@VM-12-3-ubuntu:~#

4.2、将所有用户的读取、写入和执行权限添加到目录test_dir中

root@VM-12-3-ubuntu:~# ls -l
total 8
-rwxr-xr-- 1 root root    0 Jan 29 14:27 1.txt
drwx------ 4 root root 4096 Nov 14 22:47 snap
drwxr-xr-x 2 root root 4096 Jan 30 10:00 test_dir

#a+rwx 表示将所有用户的读取、写入和执行权限添加到目录中
root@VM-12-3-ubuntu:~# chmod a+rwx test_dir
root@VM-12-3-ubuntu:~# ls -l
total 8
-rwxr-xr-- 1 root root    0 Jan 29 14:27 1.txt
drwx------ 4 root root 4096 Nov 14 22:47 snap
drwxrwxrwx 2 root root 4096 Jan 30 10:00 test_dir
root@VM-12-3-ubuntu:~#

4.3、将所有用户的写权限添加到目录test_dir中,并递归地更改其所有子目录和文件的权限

root@VM-12-3-ubuntu:~# ls -l
total 8
-rwxr-xr-- 1 root root    0 Jan 29 14:27 1.txt
drwx------ 4 root root 4096 Nov 14 22:47 snap
drwxrwxrwx 2 root root 4096 Jan 30 10:00 test_dir


#在这个命令中,-R 参数表示递归地更改目录及其所有子目录和文件的权限。a+w 表示将所有用户的写权限都添加到了目录及其所有子目录和文件上
root@VM-12-3-ubuntu:~# chmod -R a+w test_dir
root@VM-12-3-ubuntu:~# ls -l
total 8
-rwxr-xr-- 1 root root    0 Jan 29 14:27 1.txt
drwx------ 4 root root 4096 Nov 14 22:47 snap
drwxrwxrwx 2 root root 4096 Jan 30 10:00 test_dir
root@VM-12-3-ubuntu:~#

4.4、将文件所有者和所属组的只读权限添加到test.txt 文件中

#root用户默认创建文件的权限就是所有者和所属组只读权限
root@VM-12-3-ubuntu:~# touch test.txt
root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r--r-- 1 root root 0 Jan 30 11:00 test.txt

#ug+r 表示将文件所有者和所属组的读取权限添加到了文件上
root@VM-12-3-ubuntu:~# chmod ug+r test.txt
root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r--r-- 1 root root 0 Jan 30 11:00 test.txt
root@VM-12-3-ubuntu:~#

4.5、将文件所有者和其他用户执行权限添加到test.txt文件中,而不影响其所属组的权限

root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r--r-- 1 root root 0 Jan 30 11:16 test.txt

#uo+x 表示将文件所有者和其他用户的执行权限添加到了文件上,而不影响其所属组的权限
root@VM-12-3-ubuntu:~# chmod uo+x test.txt
root@VM-12-3-ubuntu:~# ls -l test.txt
-rwxr--r-x 1 root root 0 Jan 30 11:16 test.txt
root@VM-12-3-ubuntu:~#

5、chmod以数字添加权限

这些数字可以通过相加来表示不同的权限组合,例如:

常用添加数字权限例子:

5.1、将文件所有者的读、写和执行权限加到test.txt文件中

root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r--r-- 1 root root 0 Jan 31 08:43 test.txt

# 700 表示文件所有者获得读、写和执行权限,而其它用户没有任何权限
root@VM-12-3-ubuntu:~# chmod 700 test.txt
root@VM-12-3-ubuntu:~# ls -l test.txt
-rwx------ 1 root root 0 Jan 31 08:43 test.txt
root@VM-12-3-ubuntu:~#

5.2、将文件所有者的读和写权限,所属组的读权限,其他用户的读权限添加到test.txt文件中

#一开始的权限是700
root@VM-12-3-ubuntu:~# ls -l test.txt
-rwx------ 1 root root 0 Jan 31 08:43 test.txt

# 644 表示文件所有者获得读和写权限,所属组和其他用户获得只读权限
root@VM-12-3-ubuntu:~# chmod 644 test.txt
root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r--r-- 1 root root 0 Jan 31 08:43 test.txt
root@VM-12-3-ubuntu:~#

5.3、将目录 test_dir 的所有者的读、写和执行权限,所属组的读和执行权限,其他用户的执行权限添加到了目录上

#开始的权限是:文件所有者和所属组的读、写和执行权限都添加到了目录及其所有子目录和文件上
root@VM-12-3-ubuntu:~# ls -l
total 8
drwxrwxrwx 2 root root 4096 Jan 30 10:00 test_dir

#现在的权限是:750 表示文件所有者获得读、写和执行权限,所属组获得读和执行权限,其他用户获取执行权限
root@VM-12-3-ubuntu:~# chmod 750 test_dir
root@VM-12-3-ubuntu:~# ls -l
total 8
drwxr-x--- 2 root root 4096 Jan 30 10:00 test_dir
root@VM-12-3-ubuntu:~#

5.4、使文件所有者具有读、写和执行权限,而所属组和其他用户只有读和执行权限

root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r--r-- 1 root root 0 Jan 31 08:43 test.txt

# 755 表示文件所有者具有读、写和执行权限,而所属组和其他用户只有读和执行权限
root@VM-12-3-ubuntu:~# chmod 755 test.txt
root@VM-12-3-ubuntu:~# ls -l test.txt
-rwxr-xr-x 1 root root 0 Jan 31 08:43 test.txt
root@VM-12-3-ubuntu:~#

5.5、使文件所有者具有读和写权限,所属组具有读权限,其他用户没有任何权限

root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r--r-- 1 root root 0 Jan 31 10:05 test.txt

# 640 表示使文件所有者具有读和写权限,所属组具有读权限,其他用户没有任何权限
root@VM-12-3-ubuntu:~# chmod 640 test.txt
root@VM-12-3-ubuntu:~# ls -l test.txt
-rw-r----- 1 root root 0 Jan 31 10:05 test.txt
root@VM-12-3-ubuntu:~#

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文