LinuxBasicsForHackers笔记 -- 控制文件和目录权限

对于每个文件和目录,我们可以指定文件所有者、特定用户组以及所有其他用户的权限状态。

不同类型的用户

在Linux中,root用户是拥有一切权力的。 root 用户基本上可以在系统上执行任何操作。 系统上的其他用户具有有限的能力和权限,并且几乎永远不具有 root 用户所拥有的访问权限。

这些其他用户通常被收集到通常共享类似功能的组中。 在商业实体中,这些组可能是财务、工程、销售等。 在 IT 环境中,这些组可能包括开发人员、网络管理员和数据库管理员。 这个想法是将具有相似需求的人放入一个被授予相关权限的组中; 那么该组的每个成员都会继承该组的权限。 这主要是为了便于管理权限,从而提高安全性。

默认情况下,root 用户是 root 组的一部分。 系统上的每个新用户都必须添加到一个组中才能继承该组的权限。

授予权限

每个文件都必须为使用它的不同身份分配特定级别的权限。 三个级别的权限如下:

  • r – 允许阅读。 仅授予打开和查看文件的权限。
  • w – 允许写。 允许用户查看和编辑文件。
  • x – 允许执行。 允许用户执行文件(但不一定查看或编辑它)。

向个人用户授予所有权

要将文件的所有权移至其他用户,以便他们能够控制权限,我们可以使用 chown (change owner)命令:chown <用户名> <文件名>
这条命令授予用户名对应文件的拥有权。

授予组所有权

要将文件的所有权从一个组转移到另一个组,我们可以使用 chgrp(change group)命令。
chgrp <组名> <文件或目录名>

检查权限

当您想要了解授予哪些用户对某个文件或目录的权限时,请使用ls -l <文件/目录名>命令显示 — 此列表将包含权限,会出现以下相似内容:

在这里插入图片描述
对上图的解释:

  • 1 – 文件类型(这是列出的第一个字符),其中 d 代表目录,破折号 - 表示文件。 这是两种最常见的文件类型。
  • 2 – 分别为所有者、组和其他用户对文件的权限。如果任何 r、w 或 x 被短划线 (-) 替换,则表示尚未授予相应的权限。 请注意,用户只能有权执行二进制文件或脚本。这些权限并不是一成不变的。 作为 root 用户或文件所有者,您可以更改它们。
  • 3 – 链接数量
  • 4 – 文件的所有者
  • 5 – 文件大小(以字节为单位)
  • 6 – 文件创建或最后修改时间
  • 7 – 文件名

更改权限

我们可以使用Linux命令chmod(change mode)来更改权限。 只有 root 用户或文件所有者才能更改权限。

使用十进制更改权限

我们可以使用一个快捷方式来表示权限,即使用单个数字来表示一组 rwx 权限。您可以将 rwx 权限视为三个 ON/OFF 开关,因此当授予所有权限时,这相当于二进制的 111。

一个八进制数字代表一组三个二进制数字,这意味着我们可以用一个数字代表整个 rwx 集。 表 5-1 包含所有可能的权限组合及其八进制和二进制代表。

在这里插入图片描述
通过向 chmod 传递三个八进制数字(每个 rwx 集是一个数字),后跟一个文件名,我们可以更改每种类型用户对该文件的权限。 在命令行中输入以下内容:
chmod 774 <文件名> ,我们可以看到这条语句赋予了所有者和组所有权限,而其他人(其他)只有读取权限。

使用 UGO 更改权限

尽管数字方法可能是 Linux 中更改权限的最常见方法,但有些人发现 chmod 的符号方法更直观,两种方法效果同样好,因此只需找到适合您的一种即可。 符号方法通常称为 UGO 语法,它代表用户(或所有者)、组和其他。

UGO语法非常简单。 输入 chmod 命令,然后输入要更改其权限的对象,用户 – u,组 – g,其他 – o,后跟三个运算符之一:

  • - – 删除权限
  • + – 增加权限
  • = – 设置权限

在运算符之后,包含要添加或删除的权限 (rwx),最后包含要应用该权限的文件的名称。
因此,如果您想删除文件 hashcat.hcstat 所属用户的写权限,您可以输入以下内容:chmod u-w hashcat.hcstat

您还可以仅使用一个命令来更改多个权限。 如果您想同时授予该用户和其他用户(不包括该组)执行权限,可以输入以下内容:chmod u+x, o+x hashcat.hcstat

授予新工具的 root 执行权限

chmod 777 <文件名>,授予文件权限。

使用掩码设置更安全的默认权限

正如您所见,Linux 自动分配基本权限 — 通常为文件分配 666,为目录分配 777。 您可以使用 umask(user file-creation mask)方法更改分配给每个用户创建的文件和目录的默认权限。 umask 方法表示您想要从文件或目录的基本权限中删除的权限,以使它们更安全。

umask 是一个三位八进制数,对应于三个权限位,从权限数中减去 umask 数即可得到新的权限状态。 这意味着当创建新文件或目录时,其权限将设置为默认值减去umask中的值。

在 Debian 系统中,umask 预配置为 022,这意味着默认文件权限为 644,目录权限为 755。

umask 值并不适用于系统上的所有用户。 每个用户都可以为其个人 .profile 文件中的文件和目录设置个人默认 umask 值。 要以用户身份登录时查看当前值,只需输入命令 umask 并记下返回的内容即可。 要更改用户的 umask 值,请编辑文件 /home/username/.profile,例如添加 umask 007 进行设置,以便只有用户和用户组的成员具有权限。

特殊权限

除了rwx这三个通用权限之外,Linux还有三个稍微复杂一些的特殊权限。 这些特殊权限是设置用户 ID(或 SUID)、设置组 ID(或 SGID)和粘滞位(已经过时)。

使用 SUID 授予临时 root 权限

您现在应该知道,只有当用户有权执行某个特定文件时,他们才能执行该文件。 如果用户只有读和/或写权限,则无法执行。 这看起来似乎很简单,但这条规则也有例外。
基本上,SUID 位表示任何用户都可以在所有者的权限下执行该文件,但这些权限不会超出该文件的使用范围。

要设置 SUID 位,请在常规权限之前输入 4,因此当设置 SUID 位时,新生成的权限为 644 的文件将表示为 4644。

在文件上设置 SUID 不是典型用户会做的事情,但如果您想这样做,您将使用 chmod 命令,如 chmod 4644 <filename> 所示。

授予Root用户组权限SGID

SGID 还授予临时提升的权限,但它授予文件所有者组的权限,而不是文件所有者的权限。 这意味着,通过设置 SGID 位,如果所有者属于有权执行该文件的组,则没有执行权限的人也可以执行该文件。

SGID 位在常规权限之前表示为 2,因此当设置 SGID 位时,结果权限为 644 的新文件将表示为 2644。 同样,您可以使用 chmod 命令来执行此操作,例如 chmod 2644 <filename>

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

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

相关文章

PHP项目启动记录

PHP项目启动记录 1. 项目整体目录2. bash_profile3. nginx的conf配置4. vim /etc/hosts5. php -v6.修改nginx后重新加载nginx7. npm run watch-app --moduleattendance --platformmobile8. vim ~/.zshrc 1. 项目整体目录 2. bash_profile ~/.bash_profile是Mac系统中的一个配置…

JVM之垃圾回收与算法(四)

垃圾回收与算法 1.如何确定垃圾 1.1. 引用计数法 在 Java 中&#xff0c;引用和对象是有关联的。如果要操作对象则必须用引用进行。因此&#xff0c;很显然一个简单的办法是通过引用计数来判断一个对象是否可以回收。简单说&#xff0c;即一个对象如果没有任何与之关联的引用…

网页文章采集工具-人工智能AI功能

简数采集器是一款支持人工智能AI功能的网页文章采集工具&#xff0c;它可以调用百度的文心一言AI对采集的数据进行分析&#xff0c;处理&#xff0c;内容创作等等&#xff0c;根据你的需求进行更加灵活的数据采集和处理。 文心一言人工智能AI功能使用方法&#xff1a; 1. 填写…

7、Qt延时的使用

一、说明 平时用到两种延时方式QThread::sleep()和QTimer::singleShot() 1、QThread::sleep() QThread类中如下三个静态函数&#xff1a; QThread::sleep(n); //延迟n秒 QThread::msleep(n); //延迟n毫秒 QThread::usleep(n); //延迟n微妙 这种方式使用简单&#xff0c;但是会阻…

OpenAI发布一周年,那些声称超过它的模型都怎么样了?

这篇报告详尽地回顾了自ChatGPT发布一年以来&#xff0c;各种声称与ChatGPT相当或更优的开源大语言模型在各种任务上的表现&#xff01;报告整合了各种评估基准&#xff0c;分析了开源LLMs与ChatGPT在不同任务上的比较。 包括一般能力、代理能力、逻辑推理能力、长文本建模能力…

Java生成word[doc格式转docx]

引入依赖 <!-- https://mvnrepository.com/artifact/org.freemarker/freemarker --><dependency><groupId>org.freemarker</groupId><artifactId>freemarker</artifactId><version>2.3.32</version></dependency> doc…

Mybatis中的设计模式

Mybatis中的设计模式 Mybatis中使用了大量的设计模式。 以下列举一些看源码时&#xff0c;觉得还不错的用法&#xff1a; 创建型模式 工厂方法模式 DataSourceFactory 通过不同的子类工厂&#xff0c;实例化不同的DataSource TransactionFactory 通过不同的工厂&#xff…

17:00面试,17:06就出来了,问的问题有点变态。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到8月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40%,…

css新闻链接案例

利用html和css构建出新闻链接案例&#xff0c;使用渐变色做出背景色变化 background: linear-gradient(to bottom, rgb(137, 210, 251), rgb(238, 248, 254), white); 利用背景图片&#xff0c;调整位置完成 dd { height: 28px; line-height: 28px; background-image: url(./图…

@Scheduled,Quartz,XXL-JOB三种定时任务总结

Scheduled&#xff0c;Quartz&#xff0c;XXL-JOB三种定时任务总结 一、Scheduled 简介 Scheduled 是 Spring 框架中用于声明定时任务的注解。通过使用 Scheduled 注解&#xff0c;你可以指定一个方法应该在何时执行&#xff0c;无需依赖外部的调度器。 这个注解通常与Enab…

判断是否存在重复的数

系列文章目录 进阶的卡莎C_睡觉觉觉得的博客-CSDN博客数1的个数_睡觉觉觉得的博客-CSDN博客双精度浮点数的输入输出_睡觉觉觉得的博客-CSDN博客足球联赛积分_睡觉觉觉得的博客-CSDN博客大减价(一级)_睡觉觉觉得的博客-CSDN博客小写字母的判断_睡觉觉觉得的博客-CSDN博客纸币(C…

(C语言)通过循环按行顺序为一个矩阵赋予1,3,5,7,9,等奇数,然后输出矩阵左下角的值。

#include<stdio.h> int main() {int a[5][5];int n 1;for(int i 0;i < 5;i ){for(int j 0;j < 5;j ){a[i][j] n;n 2;}}for(int i 0;i < 5;i ){for(int j 0;j < i;j )printf("%-5d",a[i][j]);printf("\n");}return 0; } 运行截图…

深入理解JVM内存空间的担保策略

Java虚拟机&#xff08;JVM&#xff09;的内存管理是Java性能调优中最重要的方面之一&#xff0c;特别是在处理大型应用和服务时。JVM内存管理的一个关键组成部分是垃圾回收&#xff08;GC&#xff09;。在GC过程中&#xff0c;JVM需要确保有足够的内存来创建新对象&#xff0c…

STM32串口接收不定长数据(空闲中断+DMA)

玩转 STM32 单片机&#xff0c;肯定离不开串口。串口使用一个称为串行通信协议的协议来管理数据传输&#xff0c;该协议在数据传输期间控制数据流&#xff0c;包括数据位数、波特率、校验位和停止位等。由于串口简单易用&#xff0c;在各种产品交互中都有广泛应用。 但在使用串…

C陷阱与缺陷——第2章语法陷阱

1. 理解函数声明 硬件将调用首地址为0位置的子例程 (*(void(*)())0)(); 任何C变量的声明都由两部分组成&#xff1a;类型以及一组类似表达式的声明符&#xff0c;声明符从表面看与表达式有些类似&#xff0c;对它求值应该返回一个声明中给定类型的结果。 假定变量fp是一个函…

揭秘预付费电表怎么无线收费——方便快捷收费

【摘要】针对目前市场上普遍以Ic卡作为售电介质的预付费售电系统存在的问题&#xff0c;介绍了一种新型的无线预付费售电系统及其构成&#xff0c;并给出了整个系统设计的完整方案。整个系统包括用户终端和电力管理系统端&#xff0c;它们之间通过双工通信可以将用户用电信息和…

Kubernetes存储搭建NFS挂载失败处理

搞NFS存储时候发现如下问题&#xff1a; Events:Type Reason Age From Message---- ------ ---- ---- -------Normal Scheduled 5m1s default-scheduler Successful…

电子学会全国青少年软件编程等级考试 中小学生python一级历年真题解析【更新至2023年9月 持续更新】

中国电子学会python等级考试一级历年真题解析 一、考级知识点分析 一、 了解Python多种开发环境&#xff0c;熟练使用Python自带的IDLE开 发环境&#xff0c;能够进行程序编写、调试和分析&#xff0c;具备使用Python开发 环境进行程序设计的能力 了解Python常见的几种编程环…

堆排序详细解读

简介 堆排序是一种基于二叉堆数据结构的排序算法&#xff0c;它的特点是不同于传统的比较排序算法&#xff0c;它是通过建立一个堆结构来实现的。堆排序分为两个阶段&#xff0c;首先建立堆&#xff0c;然后逐步将堆顶元素与堆的最后一个元素交换并调整堆&#xff0c;使得最大…

EM32DX-C2【C#】

1说明&#xff1a; 分布式io&#xff0c;CAN总线&#xff0c;C#上位机二次开发&#xff08;usb转CAN模块&#xff09; 2DI&#xff1a; 公共端是&#xff1a; 0V【GND】 X0~X15&#xff1a;自带24v 寄存器地址&#xff1a;0x6100-01 6100H DI输入寄存器 16-bit &#x…