当前位置: 首页 > article >正文

第6章:文件权限

一、文件权限概述

Linux为了保证系统中每个文件的安全,引入了文件权限机制。针对于系统中的每一个文件Linux都可以提供精确的权限控制。它可以做到不同的用户同一个文件具有不同的操作权利。而通常这个权利包括以下3个:

  • 读的权利(Read,简称r)

  • 写的权利(Write,简称w)

  • 执行的权利(eXecute,简称x)

具体的权限值:rwx(读、写、执行)。这个我们已经知道了。但是上面还提到了“不同的用户对同一个文件可以有不同的权限”中“不同的用户”指的是哪些用户呢?所以这个文件的用户也是包括3类用户:

  • 文件拥有者(User,简称U):该文件的创建人

  • 同组用户(Group,简称G):和创建人在同一组的用户

  • 其他组用户(Other,简称O):和创建人不在同一组的用户

这就是非常著名的UGO模型。也就是说一个文件的权限包括三组:

  • 第一组U:我们可以给文件的创建者设置rwx权限。

  • 第二组G:我们可以给文件创建者的同组人员设置rwx权限。

  • 第三组O:我们可以给和文件创建者不在同一组的人员设置rwx权限。


linux操作系统当中,可执行文件的扩展名一般叫做:xxx.sh

windows操作系统当中,可执行文件的扩展名一般叫做:xxx.exe


二、查看文件权限

采用“ls -l”命令可以查看文件的具体权限,如下:

权限信息在哪里呢?看下图:

每一个文件或目录采用ls -l查看之后,第一个字段描述了文件类型+文件的权限。第一个字段共10个字符:

  • 第1个字符:代表文件的类型,- 代表文件,d代表目录

    • 其实Linux中文件的类型有7种:

        • 代表普通文件

      • d 代表目录

      • l 代表链接(软链接:快捷方式)

      • b 块设备(硬盘,软盘等存储设备)

      • c 字符设备(通常以字节流的方式访问)

      • p 管道文件(主要用于进程间通讯)

      • s 套接字文件(主要用于网络通讯)

  • 第2,3,4个字符:代表文件创建者对该文件的权限。

  • 第5,6,7个字符:代表与文件创建者在同一组的用户对该文件的权限。

  • 第8,9,10 个字符:代表其他组人员对该文件的权限。

关于文件权限的9个字符中包含四种字符,分别是:r、w、x、-,他们代表什么含义:

  • r:读权限

  • w:写权限

  • x:执行权限

  • -:无权限

三、基于UGO设置文件权限

修改权限的命令是chmod,如果采用UGO方式修改权限的话,大致语法是这样的:

给同组人员添加写权限

chmod g+w Hello.java

给同组人员和其他人员添加写权限

chmod g+w, o+w Hello.java

删除同组人员和其他人员写的权限

chmod g-w, o-w Hello.java

四、基于421设置文件权限

421采用数字来表示不同的权限。

  • 4代表读

  • 2代表写

  • 1代表执行

例如:如果让一个用户读、写、执行权限都有的话,就是4 + 2 + 1 = 7,那么7这个数字就代表rwx的权限都具备。如果是5就表示4+1的组合,表示有r和x的权限。如果是6就表示4+2的组合,表示有r和w的权限。如果是0就表示无任何权限。 通过421这几个数字的不同组合来表示不同的权限,那么它有多少种不同的组合呢:

  • 0:无权限

  • 1:x

  • 4:r

  • 5:r + x

  • 6:r + w

  • 7:r + w + x

也就是说一共6个数字:0 1 4 5 6 7 那么采用421方式设置权限应该怎么做呢,比如:如何给文件拥有者设置权限,如何给同组人员设置权限,如何给其他组人员设置权限?语法是这样的:

chmod 三个数字 文件名

五、chown修改文件拥有者

在 Linux 中,可以使用 `chown` 命令来修改指定文件或目录的拥有者和所属组。`chown` 命令的基本语法如下:

chown [选项]... [所有者][:[所属组]] 文件...

其中,所有者所属组 可以是用户名或用户 ID、组名或组 ID,如果省略 :所属组,则默认为修改文件的所有者。

下面是一些常用选项:

  • -R:递归修改,包括子目录和文件。

例如,将 /home/user/file.txt 文件的所有者修改为 root 用户,可以使用如下命令:

sudo chown root /home/user/file.txt

/home/user/dir/ 目录及其子目录和文件的所有者都修改为 userA 用户,所属组修改为 groupA 组,可以使用如下命令:

sudo chown -R userA:groupA /home/user/dir/

注意,在使用 chown 命令时,需要有足够的权限才能修改文件或目录的拥有者和所属组。一般需要使用 sudo 命令或使用具有相应权限的用户来执行。

http://www.lryc.cn/news/2378495.html

相关文章:

  • 使用 Python 连接 Oracle 23ai 数据库完整指南
  • C语言| 指针变量的定义
  • HTML 中的 input 标签详解
  • Python 在自动驾驶数据标签中的应用:如何让 AI 读懂道路?
  • 微信小程序之按钮短时间内被多次点击问题
  • 动态规划(3)学习方法论:构建思维模型
  • 两个电机由同一个控制器控制,其中一个电机发生堵转时,另一个电机的电流会变大,是发生了倒灌现象吗?电流倒灌产生的机理是什么?
  • Java 方法向 Redis 里操作字符串有什么需要注意的?​
  • ECMAScript 2018(ES2018):异步编程与正则表达式的深度进化
  • IntelliJ IDEA给Controller、Service、Mapper不同文件设置不同的文件头注释模板、Velocity模板引擎
  • 从零开始认识 Node.js:异步非阻塞的魅力
  • 【C语言练习】046. 编写插入排序算法
  • 【论文阅读】BEVFormer
  • IDEA编辑器设置的导出导入
  • 手动实现 Transformer 模型
  • 成功案例丨从草图到鞍座:用先进的发泡成型仿真技术变革鞍座制造
  • BG开发者日志517:demo数据分析与修改方向
  • Linux靶机网站配置:从零搭建Web靶场环境
  • 电机试验平台:创新科技推动电动机研究发展
  • STM32F103定时器1每毫秒中断一次
  • 【springcloud学习(dalston.sr1)】Zuul路由访问映射规则配置及使用(含源代码)(十二)
  • Qt与Hid设备通信
  • 2024 山东省ccpc省赛
  • SAP HCM 0008数据存储逻辑
  • Elasticsearch 查询与过滤(Query vs. Filter)面试题
  • golang读、写、复制、创建目录、删除、重命名,文件方法总结
  • 如何使用通义灵码辅助学习C++编程 - AI编程助手提升效率
  • 解决LeetCode 47. 全排列 II 问题的正确姿势:深入分析剪枝与状态跟踪
  • ubuntu18 设置静态ip
  • 【Docker】CentOS 8.2 安装Docker教程