【看表情包学Linux】shell 命令及运行原理 | Linux 权限 | 文件权限的修改和转让 | 目录的权限 | Sticky bit 粘滞位(二)

简介: 本章我们将重点讲解 Linux 权限,这是 Linux 基础部分中非常重要的一部分。内容比较干,我会稍稍正经些去讲解。话不多说,我们直接切入正题。

Ⅳ. 文件权限的转让


0x00 chown 指令

chown [用户名] [文件名]     # 修改文件的拥有者

如果我是一个文件的拥有者,我想把文件给别人:

87466b2d252fdb65147a3af1670f1054_68d6c303948f46938be3cd131ea5e9d9.png


❓ 思考:当你想给别人东西的时候,要不要经过别人的同意?


当然需要!这里我们可以用 sudo 指令强制给别人:

f9e03fec372296ad1570c906c5b9c7e1_822145dbb62f4e28a47b52d1f17c66a3.png


(sudo 有一个叫信任列表的东西,你现在输入如果出现报错是因为 root 没有把你添加到信任列表里,这个我们后期讲完 vim 之后再说。在 /etc/sudoers 路径下。)


当然我们还可以直接切换成 root,通过 root 去给,别人不要也不行,就是这么🐂🍺。


(root 无视权限)


一个文件的创建者和拥有者一定是同一个人吗?


通过我们刚才修改文件的拥有者,我们就能得出 —— 不一定。


0x01 chgrp 指令

chgrp [用户名] [文件名]     # 修改文件的所属组

和 chown 一样的用法,我们可以用 chgrp 指令改变文件的所属组 group。

927f39317f633cad66962e827c644692_fcbdf885d1cf45aaa978d3161b65d0d3.png


Ⅴ. 目录的权限


0x00 目录的权限

78a8e2f33e88f9ff78b530a82a88e001_510542c49fe9421bb929605de03ac675.png


我们来去掉  权限,看看到底能不能进入这个 dir:

84f137dd79aaf42024f00144738ab1d1_f6422cfd427a480088a12108019611f3.png


这就说明进入一个目录跟   没有关系。

dce1e0775c43c82e772b03dd6ea992a9_9987b1250e4c43208e67a0bb32ee734a.png


❓ 如果我想进入一个目录,需要说明权限?


如果目录只没有  权限,允许进入、允许在该目录下创建(写入)文件,只不过是不允许查看:

c9a5f4202558f2118b74487f8d09920e_ac263856f8a44ff196e1fce9e08aa6c2.png


如果目录只没有  权限,允许进入,允许在该目录下查看文件列表,但是不允许创建文件:

7f05375764dd3a61a7f3d98590026527_76346a558e0e4492a307211a28065d6d.png


如果同时没有  权限,允许进入,但是不允许创建和查看目录下的文件列表:


(注意:不是文件内容,文件的内容是否可以查看由文件自己的权限决定)

3cbe0dcc8a717ef1f3cd37f4c1a28e37_4f95c6bc28e34358ac1e1831f3c97421.png


💡 Linux 下一切皆文件,目录也是文件。再结合 "文件 = 内容 + 属性" 去理解。


目录里面保存的是部分文件的 "属性" 。


(文件名和 id 之间是有对应的映射关系的,有可能被系统缓存了)


0x01 默认创建后的权限

d13bc9bebb19b4109f5044417b0ff17e_fcd9418f2adf4300a6de9c864d85bb48.png


为什么创建目录的默认权限是 775,而创建普通文件的默认权限是 664 ?


不同系统可能有差异吗?


创建的时候为什么不可以都是 777,权限都给我怼上呢?


📚 默认权限:① 默认目录的起始权限:777      ② 默认普通文件的权限:666


既然如此,那为什么不是 777 / 666,而是 775 / 664 呢?


💡 默认权限 != 最终权限,Linux 中的最终权限 = 默认权限 "去掉" umask 中存在的权限。


0x02 umask 权限掩码

因为系统中有一个默认的 "权限掩码" ,叫做 umask:


umask     # 打印权限掩码

1438a009124fb1c54ba302935412e022_a6f146dfff664556ad04a5ff7223dee9.png


📚 权限掩码:凡是在权限掩码中出现的权限,都不应该在最终权限中出现!

4761c26fbf252b46d416e436a8b2d89f_cfacc62b2c9d412eb551cfc9628526a5.png



所以,最后目录的默认权限变为了 775,文件权限变为了 664。


❓ 思考:所谓的 "去掉" umask 中的权限,是不是减去呢?


💡 这里的 "去掉" 并不是减去。首先要说的是,umask 是可以修改的:


umask [掩码]      # 修改umask掩码

db7da98bc9b75b7b748663d99ac41eca_1ea01249f27346cd90fdee8f8d54e283.png

由此可见,我们的权限确实是受 umask 的影响的。但是实际上是这样计算的:


最终权限 = 默认权限 & (~umask)

Ⅵ. 粘滞位(Sticky bit)


0x00 共享目录

Linux 下可以存在一些目录,拥有者和所属组是 root,


其他人允许以 other 的身份在该目录下进行文件的创建、读取、删除和修改等操作:

04525101c5177003484caa738f617df2_9ab5ca870ecc46549b7f3f6ac2da6d8d.png


📌 注意事项:在一个共享目录下,你不让我写,不让我读,但防不住我删除!


比如,有两个普通用户,用户A想让用户B访问它的文件,于是就 chmod 把 other 的  全撤咯,


于是用户B急了,恼羞成怒,啊你不给我用你也别想用了,得不到就毁掉!直接给你把文件删了。


如果你仍然是想在共享目录下形成临时文件,但又怕别人给你删了,


你可以给共享的 <目录> 加上粘滞位来解决。


注意,是给目录加粘滞位!即你共享哪个目录,你就在哪个目录下加上粘滞位。


我们下面来隆重介绍一下 Sticky bit ——粘滞位。


0x01 粘滞位

chmod +t [目录名]     # 添置粘滞位

💭 以 root 身份给 all 目录添置粘滞位:


8328f19999ac09437c2d35649fae23dd_9e443a3eed714efc8945d9de9bd843f5.png


目录设置了粘滞位  后,作为 other 就无法随意地删除其他用户的文件了:

32f964f91d526edb74007a3fb94abc12_338180c6724f4f2e99cbcac35e457be3.png


不过 root 还是想删就删,想干啥就干啥。


还是那句话 —— 普通用户再怎么进行文件操作,对 root 都是无效的。

07c03ae6d77b4b153f6d1ec710be7c14_7a80245f0b5f4021a033b3789a9efdeb.png

相关文章
|
2月前
|
Linux 数据安全/隐私保护
linux特殊权限!!
本文介绍了Linux系统中的特殊权限,包括suid、sgid和sbit。suid使普通用户在执行特定命令时获得root权限;sgid使用户在创建文件时继承目录的用户组权限;sbit确保用户只能删除自己在共享目录中创建的文件。此外,文章还讲解了chattr和lsattr命令,用于更改和查看文件的扩展属性,以及umask的概念和计算方法,帮助理解文件和目录的默认权限。
48 1
linux特殊权限!!
|
2月前
|
存储 Shell Linux
Linux 如何更改默认 Shell
Linux 如何更改默认 Shell
46 0
Linux 如何更改默认 Shell
|
3月前
|
Web App开发 网络协议 Linux
linux命令总结(centos):shell常用命令汇总,平时用不到,用到就懵逼忘了,于是专门写了这篇论文,【便持续更新】
这篇文章是关于Linux命令的总结,涵盖了从基础操作到网络配置等多个方面的命令及其使用方法。
82 1
linux命令总结(centos):shell常用命令汇总,平时用不到,用到就懵逼忘了,于是专门写了这篇论文,【便持续更新】
|
2月前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
Unix Shell Linux
|
5月前
|
Shell Linux 程序员
在Linux中, 什么是shell函数?如何使用它们?
在Linux中, 什么是shell函数?如何使用它们?
|
8月前
|
Shell Linux C语言
Linux中执行Shell的函数(popen,system,exec)介绍:分享一些常用的执行Shell的函数及其相关编程技巧和经验
Linux中执行Shell的函数(popen,system,exec)介绍:分享一些常用的执行Shell的函数及其相关编程技巧和经验
257 0