Linux关于文件与目录的权限管理,一篇就够了

简介: 1.Linux权限概述Linux 系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux 系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。


1.Linux权限概述


Linux 系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。


为了保护系统的安全性,Linux 系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。


在 Linux 中我们通常使用以下两个命令来修改文件或目录的所属用户与权限:


chown (change owner) : 修改所属用户与组。

chmod (change mode) : 修改用户的权限。

下图中通过 chown 来授权用户,通过 chmod 为用户设置可以开门的权限。



a342e91cd83a43c6805baea427150688.png


2.文件目录权限解析


在 Linux 中我们可以使用 ll 或者 ls –l 命令来显示一个文件的属性以及文件所属的用户和组,如:


──(root㉿kali)-[~/Desktop/temp2]
└─# ll     
total 8
drwxr-xr-x 2 root root 4096 Sep 14 04:34 asd
drwxr-xr-x 3 root root 4096 Sep 14 04:43 temp


实例中,第一个属性用 d 表示。d 在 Linux 中代表该文件是一个目录文件。


在 Linux 中第一个字符代表这个文件是目录、文件或链接文件等等👍


当为 d 则是目录

当为 - 则是文件;

若是 l 则表示为链接文档(link file);

若是 b 则表示为装置文件里面的可供储存的接口设备(可随机存取装置);

若是 c 则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。

接下来的字符中,以三个为一组,且均为 rwx 的三个参数的组合。其中, r 代表可读(read)、 w 代表可写(write)、 x 代表可执行(execute)。 要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号 - 而已。


每个文件的属性由左边第一部分的 10 个字符来确定(如下图)


272f2ea22547427ba96187bddd1a116e.png


从左至右用 0-9 这些数字来表示。


第 0 位确定文件类型,第 1-3 位确定属主(该文件的所有者)拥有该文件的权限。


第4-6位确定属组(所有者的同组用户)拥有该文件的权限,第7-9位确定其他用户拥有该文件的权限。


其中,第 1、4、7 位表示读权限,如果用 r 字符表示,则有读权限,如果用 - 字符表示,则没有读权限;


第 2、5、8 位表示写权限,如果用 w 字符表示,则有写权限,如果用 - 字符表示没有写权限;第 3、6、9 位表示可执行权限,如果用 x 字符表示,则有执行权限,如果用 - 字符表示,则没有执行权限。


3.Linux文件属主和属组


对于文件来说,它都有一个特定的所有者,也就是对该文件具有所有权的用户。


同时,在Linux系统中,用户是按组分类的,一个用户属于一个或多个组


文件所有者以外的用户又可以分为文件所属组的同组用户和其他用户


因此,Linux系统按文件所有者、文件所有者同组用户和其他用户来规定了不同的文件访问权限


对于 root 用户来说,一般情况下,文件的权限对其不起作用😢


4.更改文件属性


更改文件属组


语法:


chgrp [-R] 属组名 文件名


参数选项

-R:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。

例如下面的这个例子,修改文件属组为master:


┌──(root㉿kali)-[~/Desktop]
└─# chgrp master total.tar.gz
┌──(root㉿kali)-[~/Desktop]
└─# ll
total 16
drwxr-xr-x 2 root root   4096 Sep 14 04:34 asd
drwxr-xr-x 3 root root   4096 Sep 14 04:43 temp
drwxr-xr-x 4 root root   4096 Sep 14 04:52 temp2
-rw-r--r-- 1 kali master  192 Sep 14 04:49 total.tar.gz


更改文件属主


更改目录下面的total.tar.gz属主为kali用户:


┌──(root㉿kali)-[~/Desktop]
└─# ll     
total 16
drwxr-xr-x 2 root root 4096 Sep 14 04:34 asd
drwxr-xr-x 3 root root 4096 Sep 14 04:43 temp
drwxr-xr-x 4 root root 4096 Sep 14 04:52 temp2
-rw-r--r-- 1 root root  192 Sep 14 04:49 total.tar.gz
┌──(root㉿kali)-[~/Desktop]
└─# chown kali total.tar.gz
┌──(root㉿kali)-[~/Desktop]
└─# ll
total 16
drwxr-xr-x 2 root root 4096 Sep 14 04:34 asd
drwxr-xr-x 3 root root 4096 Sep 14 04:43 temp
drwxr-xr-x 4 root root 4096 Sep 14 04:52 temp2
-rw-r--r-- 1 kali root  192 Sep 14 04:49 total.tar.gz


更改文件权限


Linux文件属性有两种设置方法,一种是数字,一种是符号。


Linux 文件的基本权限就有九个,分别是 owner/group/others(拥有者/组/其他) 三种身份各有自己的 read/write/execute 权限。


各权限的分数对照表如下:


r:4

w:2

x:1

每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为: -rwxrwx- - -分数则是:


owner = rwx = 4+2+1 = 7
group = rwx = 4+2+1 = 7
others= --- = 0+0+0 = 0


所以等一下我们设定权限的变更时,该文件的权限数字就是 770。变更权限的指令 chmod 的语法是这样的:


chmod [-R] xyz 文件或目录


选项与参数:

xyz : 就是刚刚提到的数字类型的权限属性,为 rwx 属性数值的相加。

-R : 进行递归(recursive)的持续变更,以及连同次目录下的所有文件都会变更

举例来说,如果要将 total.tar.gz 这个文件所有的权限都设定启用,那么命令如下:


┌──(root㉿kali)-[~/Desktop]
└─# ll      
total 16
drwxr-xr-x 2 root root   4096 Sep 14 04:34 asd
drwxr-xr-x 3 root root   4096 Sep 14 04:43 temp
drwxr-xr-x 4 root root   4096 Sep 14 04:52 temp2
-rw-r--r-- 1 kali master  192 Sep 14 04:49 total.tar.gz
┌──(root㉿kali)-[~/Desktop]
└─# chmod 777 total.tar.gz   
┌──(root㉿kali)-[~/Desktop]
└─# ll
total 16
drwxr-xr-x 2 root root   4096 Sep 14 04:34 asd
drwxr-xr-x 3 root root   4096 Sep 14 04:43 temp
drwxr-xr-x 4 root root   4096 Sep 14 04:52 temp2
-rwxrwxrwx 1 kali master  192 Sep 14 04:49 total.tar.gz
目录
相关文章
|
4月前
|
Linux 开发工具
7种比较Linux中文本文件的最佳工具
7种比较Linux中文本文件的最佳工具
7种比较Linux中文本文件的最佳工具
|
2月前
|
存储 数据管理 Linux
区分Linux中.tar文件与.tar.gz文件的不同。
总之,".tar"文件提供了一种方便的文件整理方式,其归档但不压缩的特点适用于快速打包和解压,而".tar.gz"文件通过额外的压缩步骤,尽管处理时间更长,但可以减小文件尺寸,更适合于需要节约存储空间或进行文件传输的场景。用户在选择时应根据具体需求,考虑两种格式各自的优劣。
347 13
|
3月前
|
安全 Linux
Linux赋予文件000权限的恢复技巧
以上这些步骤就像是打开一扇锁住的门,步骤看似简单,但是背后却有着严格的逻辑和规则。切记,在任何时候,变更文件权限都要考虑安全性,不要无谓地放宽权限,那样可能
124 16
|
3月前
|
存储 Linux 数据处理
深入剖析Linux中一切即文件的哲学和重定向的机制
在计算机的奇妙世界中,Linux的这套哲学和机制减少了不同类型资源的处理方式,简化了抽象的概念,并蕴藏着强大的灵活性。就像变戏法一样,轻轻松松地在文件、程序与设备之间转换数据流,标准输入、输出、错误流就在指尖舞动,程序的交互和数据处理因此变得既高效又富有乐趣。
54 4
|
4月前
|
Linux
【Linux】 Linux文件I/O常见操作技巧
以上就是Linux文件I/O操作的一些技巧,接纳它们,让它们成为你在Linux世界中的得力伙伴,工作会变得轻松许多。不过记住,技巧的运用也需要根据实际情况灵活掌握,毕竟,最适合的才是最好的。
122 28
|
4月前
|
Ubuntu Linux
"unzip"命令解析:Linux下如何处理压缩文件。
总的来说,`unzip`命令是Linux系统下一款实用而方便的ZIP格式文件处理工具。本文通过简明扼要的方式,详细介绍了在各类Linux发行版上安装 `unzip`的方法,以及如何使用 `unzip`命令进行解压、查看和测试ZIP文件。希望本文章能为用户带来实际帮助,提高日常操作的效率。
577 12
|
5月前
|
Linux 定位技术
Linux系统中的cd命令:目录切换技巧
踏过千山,越过万水,人生就是一场不断前行的旅程,总充满了未知与挑战。然而,“cd”命令如同你的旅伴,会带你穿梭在如棋盘一般的文件系统中,探索每一处未知。希望你能从“cd”命令中找到乐趣,像是掌控了一种络新妙的魔法,去向未知进发,开始你的探索之旅。
223 24
|
3月前
|
Linux
linux文件重命名命令
本指南介绍Linux文件重命名方法,包括单文件操作的`mv`命令和批量处理的`rename`命令。`mv`可简单更改文件名并保留扩展名,如`mv old_file.txt new_name.txt`;`rename`支持正则表达式,适用于复杂批量操作,如`rename 's/2023/2024/' *.log`。提供实用技巧如大小写转换、数字序列处理等,并提醒覆盖风险与版本差异,建议使用`-n`参数预览效果。
|
5月前
|
Linux Shell
Linux系统下快速批量创建和删除文件的方法
总的来说,使用shell脚本来批量处理文件是一种非常强大的工具,只要你愿意花时间学习和实践,你会发现它能大大提高你的工作效率。
291 19
|
6月前
|
监控 Linux
Linux基础:文件和目录类命令分析。
总的来说,这些基础命令,像是Linux中藏匿的小矮人,每一次我们使用他们,他们就把我们的指令准确的传递给Linux,让我们的指令变为现实。所以,现在就开始你的Linux之旅,挥动你的命令之剑,探索这个充满神秘而又奇妙的世界吧!
128 19