<Linux>权限管理|权限分类|权限设置|权限掩码|粘滞位

文章目录

  • Linux权限的概念
  • Linux权限管理
    • a. 文件访问者的分类
    • b. 文件类型和访问权限
    • c. 文件权限表示方法
    • d. 文件权限的设置
    • 权限掩码
    • file指令
    • 粘滞位
  • 权限总结
  • 权限作业

Linux权限的概念

Linux下有两种用户:超级用户(root)和普通用户。

  • 超级用户:可以在Linux系统下做任何事情,不受限制
  • 普通用户:在Linux下做有限的事
  • 超级用户的提示符是“#”,普通用户的提示符是“$”
    image-20230806165553469

命令su用来切换用户
语法:su 用户名
功能:切换用户
例如,从root切换为sy,只需要su sy即可,若从普通用户切换为超级用户可以su root,root可以省略(切换为超级用户时需要输入root密码)

Linux权限管理

我们针对一件事可不可以被做时需要考虑两方面,一是这件事针对的不同的对象是否可以被做,二是这件事本身是否可以被做。

Linux中的权限也应该从这两方面考虑

  1. 文件访问者的分类(人)
  2. 文件类型和访问权限(事物属性)

a. 文件访问者的分类

访问者一般分为以下3类

  • 文件和目录的所有者:u—User
  • 文件和目录的所有者所在的组的用户:g—Group
  • 其他用户:o—Others

b. 文件类型和访问权限

文件信息:

image-20230806171024029

文件类型:

d:文件夹

-:普通文件(源文件、可执行文件)

l:软链接(类似Windows的快捷方式)

b:块设备文件(例如硬盘、光驱等)

p:管道文件

c:字符设备文件(例如屏幕等串口设备)

s:套接口文件

基本权限:

i.读(r/4):Read对文件而言,具有读取文件内容的权限;对目录来说,具有浏览该目录信息的权限

ii.写(w/2):Write对文件而言,具有修改文件内容的权限;对目录来说具有删除移动目录内文件的权限

iii.执行(x/1):execute对文件而言,具有执行文件的权限;对目录来说,具有进入目录的权限

iv.“-”表示不具有该项权限

c. 文件权限表示方法

字符表示

Linux表示说明
---文件目录不可读不可写不可执行
r --文件目录只可读
-w-文件目录只可写
--x文件目录只可执行
rw-文件目录可读可写
r-x文件目录可读可执行
-wx文件目录可写可执行
rwx文件目录可读可写可执行

进制表示

权限符号8进制表示二进制表示说明
---0000文件目录不可读不可写不可执行
r --4100文件目录只可读
-w-2010文件目录只可写
--x1001文件目录只可执行
rw-6110文件目录可读可写
r-x5101文件目录可读可执行
-wx3011文件目录可写可执行
rwx7111文件目录可读可写可执行

若文件的权限符号是rwxr-xr-x,则该文件的拥有者对文件可读可写可执行,所属组对文件可读可执行,其他人对文件可读可执行。该权限可以用755表示

d. 文件权限的设置

chomd
功能:修改文件目录的权限
格式:chmod [参数] 权限 文件名
参数:

R : 递归修改目录文件的权限

注意:只有root和拥有者可以更改文件权限

chmod修改权限的格式

  1. 用户表示符±=权限字符

    • +:向权限范围增加权限代号所表示的权限

    • -:向权限范围取消权限代号所表示的权限

    • =:向权限范围赋予权限代号所表示的权限

    • 用户符号:

      u:拥有者

      g:拥有者同组用

      o:其它用户

      a:所有用户

image-20230806191856310

  1. 三位八进制数字

image-20230806192531267

chown
功能:修改文件的拥有者
格式:chown [参数] 用户文件名

image-20230806193755364

chgrp
功能:修改文件或目录的所属组
格式:chgrp [参数] 用户组名 文件名
常用选项:-R 递归修改文件或目录所属组

image-20230806194049268

权限掩码

新建的文件默认权限是666,新建的目录默认权限是777,但是实际看见的文件默认权限是664,目录权限是775,这是因为umask(权限掩码)的存在image-20230806222946026

当前状态权限掩码的默认值为002(八进制)image-20230806223333958

因此实际权限=默认权限减去权限掩码

这里的减去不是数学上的减,而是将与权限掩码为1的位所对应的二进制位置为0
例如文件最初权限二进制串是110110110,掩码二进制串000000010,将文件最初权限倒数第二个二进制位变成0就是110110100
用计算机语言就是实际权限=默认权限&(~权限掩码)

ps:
root用户的默认权限掩码是0022;普通用户的默认权限掩码是0002
image-20230807101451159

为什么文件的最初权限是666呢?
因为直接创建的文件都不可以直接执行,因此将最初权限设置位666
为什么文件的最终权限是664?
因为通常情况我们不希望other可以对文件的内容进行修改,只给other读文件的权限
为什么目录的最终权限是775呢?
首先,读目录就是查看当前目录下存在的文件,写目录就是在当前目录下删除/添加文件,执行目录就是进入该目录,任意创建的一个目录,我们并不希望others可以随意删除该目录下的内容,因此将other的w权限去掉,最初权限位775.


file指令

功能语法:辨识文件类型
语法:file [选项] 文件或目录
常用选项:

  • -c 详细显示指令执行过程,便于排错或分析程序执行的情形
  • -z 尝试去解读压缩文件的内容

image-20230807101945826

粘滞位

如果现在存在这样一种情况:你是老板,你命令手下的员工小王和小李在你所创建的目录dir下共同工作,小王在dir下创建了test1.txt,小李在dir下创建了test2.txt。test1.txt对other的权限是---,因此小李不可以查看text1.txt,但是dir对other的权限一定是rwx,也就是说小李在这种情况下可以删除text1.txt。小王的初衷就是不给小李查看自己写的文件,你倒好,直接把文件给删了,是不是不太合理?,在这种情况下,我们可以设置粘滞位

语法:chmod +t 目录

image-20230807103843984

当目录被设置成粘滞位时,该目录下的文件只能被

  • 超级管理员删除
  • 该目录的所有者删除
  • 该文件的所有者删除

权限总结

  • 权限可以用字符表示:rwxrwxrwx;可以用进制表示:777
  • root用户或者文件目录的拥有者可以通过chmod改变权限
  • root用户可以通过chown改变文件的拥有者,chgrp改变文件的所属组
  • 实际权限=最初权限&(~权限掩码)

文件权限:

  1. r权限表示是否可以读取文件内容
  2. w权限表示是否可以对文件的内容进行修改
  3. x权限表示是否可以执行该文件
  4. 一般创建的文件都不具有可执行性,因此文件最初的权限是666

目录权限:

  1. r权限表示是否可以查看当前目录下所有的文件或子目录
  2. w权限表示是否可以在当前目录下创建/删除文件、子目录
  3. x权限表示是否可以cd到当前目录下
  4. 目录的最初权限是777,普通用户创建的目录最终权限是775
  5. 可以对目录设置粘滞位保证该目录下的文件不能随意被删除

权限作业

  1. 以下哪个命令输出Linux内核的版本信息:

  2. linux查看cpu占用的命令是什么?
    image-20231116223722915

  3. 在Linux系统中, 为找到文件try_grep含有以a字母为行开头的内容, 可以使用命令?
    image-20231116223757334

  4. image-20231116223854721

image-20231116223911916

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/193343.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

同花顺,通达信,东方财富股票竞价,早盘板块、概念、题材竞价数据接口

早盘板块、概念、题材竞价数据接口 量化接口地址:https://stockapi.com.cn 通过分析每天早盘的板块竞价,从而判断出今日主力资金的看好方向 地址: https://stockapi.com.cn/v1/base/bkjjzq?tradeDate2023-11-08再结合个股竞价数据筛选出自…

【LLM】基于LLM的agent应用(上)

note 在未来,Agent 还会具备更多的可扩展的空间。 就 Observation 而言,Agent 可以从通过文本输入来观察来理解世界到听觉和视觉的集成;就 Action 而言,Agent 在具身智能的应用场景下,对各种器械进行驱动和操作。 Age…

基于STM32单片机数字电压表自动切换量程及源程序

一、系统方案 1、本设计采用这STM32单片机作为主控器。 2、液晶1602显示。 3、内部ADC采集电压0-12V,自动切换档位。 二、硬件设计 原理图如下: 三、单片机软件设计 1、首先是系统初始化 u8 i; u16 a,b,c,d; u16 adcx; float adc; unsigned char datas…

如何从Android恢复出厂设置后的手机恢复数据

如果您已使用出厂设置删除了Android设备上的所有数据,或者有一段时间未使用,则需要恢复出厂设置以从Android设备中检索数据。 奇客数据恢复安卓版是一个有用的工具,可以在重置后检索Android数据。 将Android设备恢复出厂设置 如果您需要将A…

在excel中设置图表的标题

已经在excel做好了一个图,默认是没有标题的: 现在来设置一个标题。 双击图表,进入编辑状态: 右键,选择“插入标题”: 输入标题:

【AI】行业消息精选和分析(23-11-19)

行业动态 1、对标GPTs,微软连夜发布100多项更新!微软CEO:Copilot时代来了 2、英伟达联手微软推出AI代工服务 3、全新雅虎搜索将于 2024 年上线,未来还会推出更多 AI 和高级功能 4、Instagram 推出定制 AI 贴纸和滤镜功能&#xff…

excel中设置图表图例的位置

例如,在excel中已经做好了一个折线图: 可以看到,默认图例是在图表的右侧,减小了图的横向展示区域。我们可以把图例放到图的上边、或者下边。 双击图表: 鼠标放在图例上方,出现了浮动文字“图例”&#…

反弹Shell

概述 反弹shell(reverse shell)就是控制端监听在某TCP/UDP端口,被控端发起请求到该端口,并将其命令行的输入输出转到控制端。reverse shell与telnet,ssh等标准shell对应,本质上是网络概念的客户端与服务端…

Python操作Excel常用方法汇总

目录 引言 一、使用pandas库操作Excel 1、读取Excel文件 2、写入Excel文件 3、处理Excel数据 二、使用openpyxl库操作Excel 1、读取Excel文件 2、写入Excel文件 3、处理Excel数据 三、高级功能 总结 引言 Python是一种功能强大的编程语言,它可以用来处理…

记一次解决Pyqt6/Pyside6添加QTreeView或QTreeWidget导致窗口卡死(未响应)的新路历程,打死我都想不到是这个原因

文章目录 💢 问题 💢🏡 环境 🏡📄 代码💯 解决方案 💯⚓️ 相关链接 ⚓️💢 问题 💢 我在窗口中添加了一个 QTreeWidget控件 ,但是程序在运行期间,只要鼠标进入到 QTreeWidget控件 内进行操作,时间超过几秒中就会出现窗口 未响应卡死的 状态 🏡 环境 �…

代码随想录算法训练营第二十七天|39 组合总和 40 组合总和II 131分割回文串

目录 39 组合总和 40 组合总和II 131分割回文串 39 组合总和 class Solution {List<List<Integer>>res new ArrayList<>();List<Integer>newList new LinkedList<>();public List<List<Integer>> combinationSum(int[] candid…

【教3妹学编程-算法题】三个无重叠子数组的最大和

2哥 : 3妹&#xff0c;咋啦&#xff1f;一副苦大仇深的样子&#xff1f; 3妹&#xff1a;不开心呀不开心&#xff0c;羽生结弦宣布离婚。 2哥 : 羽生什么&#xff1f; 3妹&#xff1a;羽生结弦&#xff01; 2哥 : 什么结弦&#xff1f; 3妹&#xff1a;羽生结弦&#xff01;&am…