【Linux】权限篇(二)

权限目录

  • 1. 前言
  • 2. 权限
    • 2.1 修改权限
    • 2.2 有无权限的对比
    • 2.3 另外一个修改权限的方法
      • 2.3.1 更改用户角色
      • 2.3.2 修改文件权限属性
  • 3. 第一个属性列
  • 4. 目录权限
  • 5. 默认权限

1. 前言

在之前的一篇博客中分享了关于权限的一些知识,这次紧接上次的进行,有需要了解上次的可以点这个链接: link。
话不多说,继续开始权限篇。

2. 权限

2.1 修改权限

我们需要先知道,一个文件的权限,谁能修改?
一般来说有两个:一个是文件的拥有者,另外一个是root。

要修改文件的权限需要一个命令chmod
举个例子:将a.txt中拥有者的权限中,去掉r。
我们来看一下:

chmod u-r a.txt

在这里插入图片描述
也可以同时去掉多个权限,比如:将b.txt中拥有者的rw都去掉
在这里插入图片描述

可以同时去掉,当然也可以同时加上:
将a.txt中拥有者的rwx都加上:
在这里插入图片描述
这里拥有者u表示,所属组g表示,other用o表示。也可以全部都同时加减全限,此时用all

来看一个所属组的例子:
去掉a.txt中所属组r的权限:

chmod g-r a.txt

在这里插入图片描述

如果想同时操作多个对象,也是一样的,举个例子:将a.txt中拥有者去掉r,所属组去掉w。

chmod u-r,g-w a.txt

在这里插入图片描述
所以我们可以更改一个人的一个权限,一个人的多个权限,多个人的一个权限,多个人的多个权限,不过组合时用逗号做分离。

如果给所有人都加上同一个权限,可以直接用all。
举个例子:将b.txt中所有人都加上w。

chmod a+w b.txt

在这里插入图片描述
总之:
在这里插入图片描述
u,g,o位置可以随便写,但不建议。

2.2 有无权限的对比

用普通账号创建一个文件t.txt
在这里插入图片描述
去掉文件的所有权限后,执行读文件和向文件写入,发现都不行。
在这里插入图片描述

对于普通用户,自身要受到对应权限的约束,即使这个文件是直接的。


当把t.txt中所有的权限全部去掉之后,root还是想写入就能写,想读就能读。
在这里插入图片描述
root账号不受权限的约束。

当把账号切换成普通用户时,属于other,没有读写权限,我们发现不能读写t.txt。

在这里插入图片描述
所以说普通用户是受到权限的约束的。

总之:权限存在的意义就是保证普通用户的文件的一般安全性。


在身份识别的时候,只识别一次。

更改文件的拥有者,先切换到root账号下。
把文件的拥有者改为root

chown root t.txt

在这里插入图片描述
给所属组加上rw权限
在这里插入图片描述
当zxctscl不是拥有者时,自动匹配到后面的所属组。
发现所属组仍然可以读写。
在这里插入图片描述
把文件的所属组也改为root

 chgrp root t.txt

在这里插入图片描述
切换为普通账号时,发现不能读写了:
在这里插入图片描述

给other加上rw权限

chmod o+rw t.txt

在这里插入图片描述
这时使用普通账户就能继续进行读写。
在这里插入图片描述
所以说:访问一个文件时,得先判定相对于这个文件来说是拥有者、所属组还是other,然后再在这个33为一组特定的权限列表里,进行权限识别,然后才能决定到底能不能访问这个文件。

2.3 另外一个修改权限的方法

2.3.1 更改用户角色

用普通账户新建一个文件file.txt
在这里插入图片描述
想把文件的拥有者改为rjjjcph,但是不被允许:
在这里插入图片描述
所以说在把文件给别人时候,可能权限不允许,但是又要把文件给别人时,如果是普通账户就强制给,加上sudo。而root账号不需要加。

sudo chown rjjjcph file.txt

在这里插入图片描述
把指令进行提权,把文件给别人是强制给的。

把所属组也改为rjjjcph:
在这里插入图片描述
那么怎么改回去呢?
直接sudo chown

sudo chown zxctscl:zxctscl file.txt

在这里插入图片描述

也可以将拥有者改为zxctscl,将所属组改为root

sudo chown zxctscl:root file.txt

在这里插入图片描述
那么为什么不需要修改other呢?
但修改了拥有者和所属组,那么other自然也就改变了。

2.3.2 修改文件权限属性

在之前就谈到:
在这里插入图片描述
有就对应1,没有就对应0。
在这里插入图片描述
所以对于a.txt中的
拥有者: 110 -> 6
所属组:110 -> 6
other:100 -> 4
用8进制表示就是664

所以可以用8进制来表示权限。
举个例子:把所有人的所有权限都加上

chmod 777 a.txt

在这里插入图片描述
只想保留u和g的rw就是660:

chmod 660 a.txt

在这里插入图片描述
总之第二种修改文件权限属性的方法就是

chmod 八进制 filename

3. 第一个属性列

在这里插入图片描述
在window中是通过文件的后缀来判断文件类型。
Linux并不是通过文件后缀来判断的,那么它是怎么区别的呢?
通过第一个属性列来区分。

d:文件夹
-:普通文件
l:软链接(类似Windows的快捷方式)
b:块设备文件(例如硬盘、光驱等)
p:管道文件
c:字符设备文件(例如屏幕等串口设备)
s:套接口文件

常见的就是-和d.
在这里插入图片描述
mkdir创建的目录,就是以d开头。

磁盘:

在这里插入图片描述
显示器就是字符设备:

在这里插入图片描述


在这里插入图片描述
Linux系统不以文件后缀作为区分文件类型,但并不是代表gcc不需要。
所以说Linux!=gcc
也就是说Linux不区分文件类型,但是Linux上面的工具可能会区分。
所以我们可以对Linux的文件使用后缀。

4. 目录权限

如果我们进入一个目录,那么需要什么权限呢?
在这里插入图片描述
先去掉拥有者目录的r,结果显示能进入目录:
所以进入一个目录与r无关
在这里插入图片描述
但是不能查看指定目录内的信息
在这里插入图片描述


加上r,去掉w,看看能不能进入一个目录?

在这里插入图片描述

发现是可以进入目录的。
在这里插入图片描述
但是不能创建一个文件。
在这里插入图片描述


加上r,去掉w,看看能不能进入一个目录?
在这里插入图片描述
发现不能进入目录了。

总之:
目录的r权限:用户能否查看指定目录内的信息。
目录的w权限:决定用户是否能在指定目录内新建、修改、删除文件。
目录的x权限:决定用户能否进入一个目录

5. 默认权限

在Linux创建文件的时候,为什么好像有默认权限?为什么就是我们所看到的这样?
在这里插入图片描述
创建普通文件时,起始权限是:0666,去掉x
创建目录文件时,起始权限是:0777,包含x

我们使用umask来看看默认值,不同的平台可能会有不同,这个是正常的。

在这里插入图片描述
这个默认值代表创建文件时,要从起始权限中,过滤掉。

我们也可以修改默认值:
在这里插入图片描述
此时新的文件权限默认权限就改变了。
在这里插入图片描述

来计算一下普通文件,显示的权限怎么来的:
先将umask按位取反,在将666与取反之后的进行按位与,最后得到的就是664,刚好就是rw-r–r–
在这里插入图片描述
在这里插入图片描述

有错误请指出,大家一起进步吧!

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

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

相关文章

Javascript知识点锦集

【版权声明】未经博主同意,谢绝转载!(请尊重原创,博主保留追究权) https://blog.csdn.net/m0_69908381/article/details/135165704 出自【进步*于辰的博客】 文章目录 1、其他知识点链接7、关于 false8、关于 null 与 …

【智能家电】东胜物联离在线语音方案为厨电企业赋能,实现厨房智能化控制

近年来,我国厨电市场蓬勃发展。据行业统计数据显示,至今年6月,市场规模已达356亿元,同比增长8.8%。随着数字科技、物联网和人工智能的兴起,厨电产品正在朝着更智能、多功能化的方向迅速发展。 为此厨电厂商正在积极布…

【设计模式】命令模式

其他系列文章导航 Java基础合集数据结构与算法合集 设计模式合集 多线程合集 分布式合集 ES合集 文章目录 其他系列文章导航 文章目录 前言 一、什么是命令模式? 二、命令模式的优点和应用场景 三、命令模式的要素和实现 3.1 命令 3.2 具体命令 3.3 接受者 …

Unity中Shader旋转矩阵(四维旋转矩阵)

文章目录 前言一、围绕X轴旋转1、可以使用上篇文章中,同样的方法推导得出围绕X轴旋转的点阵。2、求M~rotate~ 二、围绕Y轴旋转1、可以使用上篇文章中,同样的方法推导得出围绕Y轴旋转的点阵。2、求M~rotate~ 三、围绕Z轴旋转1、可以使用上篇文章中&#x…

华为设备文件系统基础

华为网络设备的配置文件和VRP系统文件都保存在物理存储介质中,所以文件系统是VRP正常运行的基础。只有掌握了对文件系统的基本操作,网络工程师才能对设备的配置文件和VRP系统文件进行高效的管理。 基本查询命令 VRP基于文件系统来管理设备上的文件和目录…

【模式识别】探秘判别奥秘:Fisher线性判别算法的解密与实战

​🌈个人主页:Sarapines Programmer🔥 系列专栏:《模式之谜 | 数据奇迹解码》⏰诗赋清音:云生高巅梦远游, 星光点缀碧海愁。 山川深邃情难晤, 剑气凌云志自修。 目录 🌌1 初识模式识…

OpenCV-Python(19):Canny边缘检测

目录 学习目标 Canny 边缘检测原理 1.噪声抑制(噪声去除) 2.梯度计算 3.非极大值抑制 4.双阈值检测(滞后阈值) 5.边缘连接 Canny 边缘检测步骤 Canny 边缘检测的OpenCV实现 不同阈值的边缘检测效果 学习目标 了解Canny边缘检测的概念学习掌握函数cv2.Canny()的用法 …

法线贴图实现地形模型皱褶、凹凸不平的纹理效果

在线工具推荐: 3D数字孪生场景编辑器 - GLTF/GLB材质纹理编辑器 - 3D模型在线转换 - Three.js AI自动纹理开发包 - YOLO 虚幻合成数据生成器 - 三维模型预览图生成器 - 3D模型语义搜索引擎 法线贴图在3D建模中扮演着重要的角色,它通过模拟表面的微…

ERP系统成本管理:提升企业成本管控

一、ERP系统成本管理概述 ERP系统成本管理是指通过ERP系统对企业成本进行全面、实时、准确的管理和控制。它涵盖了成本核算、成本分析、成本控制等多个方面,为企业提供了一个统一、集成的成本管理平台。 二、ERP系统成本管理的优势 统一成本管理流程:E…

50 个具有挑战性的概率问题 [01/50]:袜子抽屉

一、说明 我最近对与概率有关的问题产生了兴趣。我偶然读到了弗雷德里克莫斯特勒(Frederick Mosteller)的《概率论中的五十个具有挑战性的问题与解决方案》(Fifty Challenge Problems in Probability with Solutions)一书。我认为…

JavaScript原型,原型链 ? 有什么特点?

一、原型 JavaScript 常被描述为一种基于原型的语言——每个对象拥有一个原型对象 当试图访问一个对象的属性时,它不仅仅在该对象上搜寻,还会搜寻该对象的原型,以及该对象的原型的原型,依次层层向上搜索,直到找到一个…

09.list 容器

9、list 容器 功能: 将数据进行链式存储 链表(list)是一种物理存储单元上非连续的存储结构,数据元素的逻辑顺序是通过链表中的指针链接实现的 链表的组成: 链表由一系列结点组成 结点的组成: 一个是存…