文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Linux修改权限命令chmod用法示例

2024-12-03 06:09

关注

chmod命令(change mode的缩写)用于管理文件和目录权限,并确定谁可以访问它们。现在让我们深入了解文件和目录权限的本质,以及如何修改它们。

Linux权限

为了更好地理解chmod命令是如何工作的,我们该谨慎地研究Linux文件权限模型。

在Linux中,我们具有3种类型的文件权限:读(r),写(w)和执行(x)权限。这些权限确定哪些用户可以读取,写入或执行文件。您可以使用文本或八进制(数字)表示法来分配这些权限,我们将在本教程后面讨论。

来自:https://www.linuxmi.com/linux-chmod.html

文件和目录可以属于文件(u),组(g)或其他(o)的所有者

使用ls -l命令以长格式的形式查看当前目录下所有可见文件的详细属性。该-l标志列出文件的权限。权限分为三组:用户(user)组(group)和其他(others)。

为了更好地理解文件权限,我们将列出目录的内容,如下所示:

  1. linuxmi@linuxmi:~/www.linuxmi.com$ ls -l 

从最左端开始,第一个字符/符号表示文件类型。一个连字符( - ) ,表示该文件是一个普通文件。符号d表示它是目录。符号l表示它是符号链接。

其余的9个字符分成3个三元组,每个三元组带有三个符号r(read),w(write)和x(execute)。如前所述,第一部分指向所有者权限,第二部分指示组权限,最后一部分指定其他用户对该文件或目录具有的权限。

从输出中,我们可以看到我们有4个文件和2个目录。

让我们查看下第一个文件 

  1. -rw-rw-r-- 1 linuxmi linuxmi 1087 10月 3 20:23 linuxmi.com.cpp 

对于第一个文件,-rw-rw-r–权限表示该文件的所有者具有读取和写入权限,该组还具有读取和写入权限,而其他用户仅具有读取权限。

再看看目录的权限: 

  1. drwxrwxr-x 3 linuxmi linuxmi 4096 10月 12 13:31 Linux迷 

我们可以看到目录和组的所有者拥有所有权限(读取,写入和执行),而其他用户仅具有读取和执行权限。

在三重连字符符号-表示没有权限已被授予该文件,小组或其他用户的所有者。

使用chmod命令设置文件和目录权限

在查看了文件权限以及如何查看它们之后,我们不再关注如何修改这些权限。

Linux中的chmod命令用于使用文本(符号)或数字(八进制)表示法更改文件和目录权限。它采用以下语法:

$ chmod [选项]模式文件名

只有root用户或具有sudo特权的普通用户才能更改文件或目录权限。您可以在命令语法中传递多个文件或目录,并用空格分隔。

现在让我们深入研究并查看chmod命令的不同示例。

示例1)使用数字符号分配权限

使用数字样式/符号设置权限时,请使用以下语法:

$ sudo chmod [选项]数字值文件名

数值可以为3或4个数字。但是,在大多数情况下,使用3个数字。读取,写入和执行权限采用以下值:

权限值的总和,即在三个段中的每一个中的读取,写入和执行,都占给定文件或目录的完整权限。

这是什么意思?

假设所有者具有读取,写入和执行权限,该组具有读取和执行权限,而其他用户仅具有读取权限,可以将其细分如下:

u:rwx = 7

g:rx = 5

o:r– = 4

因此,我们得到的值为754,作为给定文件的文件权限的数值。

要将读取,写入和执行权限分配给所有者,而仅将读取权限分配给组和其他用户,请运行以下命令: 

  1. $ chmod 744 www.linuxmi.com.txt 

要将所有权限分配给文件的所有者,请对该组读取和执行权限,而对其他用户则完全没有权限,请执行: 

  1. $ chmod 750 www.linuxmi.com.txt 

要将所有权限分配给文件的所有者,请对该组具有读写权限,其他用户请运行以下命令: 

  1. $ chmod 755 linuxmi.txt 

示例2)递归分配目录权限

为目录分配权限时,请使用-R标志以递归方式为其目录和子文件夹分配权限。例如:

$ chmod 755 -R 目录名 

  1. $ chmod 755 -R /home/linuxmi/linux 

示例3)使用文本表示法指定权限

分配权限的另一种方法是使用文本表示法。在此方法中,chmod命令采用标志或符号,这些标志或符号代表语法中的所有者,组,其他或所有用户(u,g和o)。

该方法不像以前的方法那样简单明了,应注意避免分配错误的权限。

这是语法的样子

$ chmod [选项] [ugoa] [– + =] [r,w,x]文件

让我们分解一下。

第一组参数[ugoa]指定权限将更改的用户类别

如果省略了这个集合,那么默认选项是a选项。

第二组选项–操作员选项[– + =] –确定是要添加权限还是要从用户类别中删除权限。选项删除

示例4)为文件分配读取权限

$ chmod o = r 文件名

上面的命令仅将用符号“ o”表示的其他用户分配给该文件的读取权限,并删除先前分配给' others '段的权限。取得具有以下权限的linuxmi.txt 

  1. linuxmi@linuxmi:~/www.linuxmi.com$ ls -l linuxmi.txt  
  2. -rwxrwxr-x 1 linuxmi linuxmi 1087 10月 3 20:23 linuxmi.txt 

分配“others (o)”段的读权限,请仅运行 

  1. linuxmi@linuxmi:~/www.linuxmi.com$ sudo chmod o=r linuxmi.txt  
  2. [sudo] linuxmi 的密码:  
  3. linuxmi@linuxmi:~/www.linuxmi.com$ ls -l linuxmi.txt  
  4. -rwxrwxr-- 1 linuxmi linuxmi 1087 10月 3 20:23 linuxmi.txt 

从输出中,我们可以看到已为“others”段分配了读取权限,而同时又失去了执行权限。这意味着=运算符将分配新的权限,而同时会删除以前的权限。

示例5)向文件和组所有者分配执行权限 

  1. linuxmi@linuxmi:~/www.linuxmi.com$ sudo chmod ug+x linuxmi.txt  
  2. linuxmi@linuxmi:~/www.linuxmi.com$ ls -l linuxmi.txt  
  3. -rwxrwxr-- 1 linuxmi linuxmi 1087 10月 3 20:23 linuxmi.txt 

上面的命令将执行权限添加到文件的所有者和组。使用我们的文件,它将变成:

示例6)为文件,组和其他分配不同的权限 

  1. sudo chmod u=rwx,g=rw,o=r filename 

上面的命令将所有权限分配给文件的所有者,将读写权限分配给组,仅将读取权限授予其他用户。

注意:如果在=运算符之后未指定任何权限,则将删除该用户段中的所有权限。

示例7)删除其他用户的所有权限 

  1. $ sudo chmod ofilename  
  2. sudo chmod olinuxmi.txt  
  3. $ sudo chmod o-rwx linuxmi.txt  

上面的命令从“其他”用户段中删除指定文件的所有权限。

该命令与以下命令具有相同的作用: 

  1. $ sudo chmod o-rwx filename 
  2. linuxmi@linuxmi:~/www.linuxmi.com$ sudo chmod olinuxmi.txt  
  3. linuxmi@linuxmi:~/www.linuxmi.com$ ls -l linuxmi.txt 
  4. -rwxrw---- 1 linuxmi linuxmi 1087 10月 3 20:23 linuxmi.txt  
  5. linuxmi@linuxmi:~/www.linuxmi.com$ sudo chmod o-rwx linuxmi.txt  
  6. linuxmi@linuxmi:~/www.linuxmi.com$ ls -l linuxmi.txt  
  7. -rwxrw---- 1 linuxmi linuxmi 1087 10月 3 20:23 linuxmi.txt 

示例8)使用模板文件分配权限

分配文件权限的另一种便捷方法是使用参考文件。在此方法中,您使用--reference=<模板文件> 选项将文件的权限设置为与另一个参考文件的权限相同。使用以下语法 

  1. $ sudo chmod –reference=ref_file filename 

例如,要将linuxmi.txt的文件权限设置为与www.linuxmi.com.py的权限相同,请运行以下命令: 

  1. $ sudo chmod --reference=www.linuxmi.com.py linuxmi.txt 

模板文件是www.linuxmi.com.py,将linuxmi.txt更改为模板文件相同的权限。

示例9)仅将执行权限分配给目录

假设我们有一个包含文件和子目录的目录,并且我们希望仅对目录分配执行权限,而不接触文件。因此,这可以通过使用以下chmod命令来实现, 

  1. $ chmod a+X * 

如果您已经注意到,我们已经使用大写的X作为执行权限,以上命令将在当前工作目录的所有目录上设置执行权限。

总结

这个话题暂时到此结束。我们查看了chmod命令,并了解了可以使用该命令更改文件权限的各种示例。 

 

来源:Linux公社内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯