Linux:【1】Linux中的文件权限概念和相关命令
Linux:【1】Linux中的文件权限概念和相关命令
- 1、什么是文件权限?
- 1.1、文件权限的表示方式
- 2、理解文件权限
- 2.1、用户权限
- 2.2、组权限
- 2.3、其他权限
- 3、设置文件权限
- 3.1、chmod 命令
- 3.2、权限符号表示法
- 3.3、权限数字表示法
- 4、查看文件权限
- 4.1、ls 命令
- 4.2、stat 命令
- 5、更改文件所有者和所属组
- 5.1、chown 命令
- 5.2、chgrp 命令
- 6、特殊权限
- 6.1、粘着位(Sticky Bit)
- 6.2、设置用户或组的默认权限
- 7、结论
1、什么是文件权限?
在 Linux 中,每个文件和目录都有相应的权限设置,用于确定哪些用户或组可以对其进行访问、读取、写入或执行操作。文件权限定义了对文件的访问级别,确保只有经过授权的用户才能对文件进行操作,从而提高系统的安全性。
1.1、文件权限的表示方式
在 Linux 中,文件权限用一串字符来表示,共有 10 个字符,可以分为四个部分:文件类型、用户权限、组权限和其他权限。
文件权限的表示方式如下:
- rwxrwxrwx
其中,每个字符的含义如下:
- 第一个字符表示文件类型。常见的文件类型包括 -(普通文件)和 d(目录)。
- 后面的三个字符表示用户权限,即文件所有者对文件的权限。
- 接下来的三个字符表示组权限,即文件所属组的用户对文件的权限。
- 最后的三个字符表示其他权限,即其他用户对文件的权限。
每个权限字符可以是以下四个字符之一:
- r(读取):允许读取文件内容、查看目录内容。
- w(写入):允许修改文件内容、在该目录中创建、删除文件。
- x(执行):对于文件,允许执行文件;对于目录,允许进入该目录。
- -(无权限):表示没有相应的权限。
2、理解文件权限
文件权限可以分为三个部分:用户权限、组权限和其他权限。下面将对每个部分进行详细说明。
2.1、用户权限
用户权限指的是文件的所有者对文件的权限。文件的所有者可以是系统中的任何用户。以下是用户权限的字符表示:
- r(读取):允许所有者读取文件内容或查看目录内容。
- w(写入):允许所有者修改文件内容或在目录中创建、删除文件。
- x(执行):对于文件,允许所有者执行文件;对于目录,允许所有者进入该目录。
- -(无权限):表示没有相应的权限。
2.2、组权限
组权限指的是文件所属组中的用户对文件的权限。每个文件都会关联一个所属组。以下是组权限的字符表示:
- r(读取):允许组成员读取文件内容或查看目录内容。
- w(写入):允许组成员修改文件内容或在目录中创建、删除文件。
- x(执行):对于文件,允许组成员执行文件;对于目录,允许组成员进入该目录。
- -(无权限):表示没有相应的权限。
2.3、其他权限
其他权限指的是不属于文件所有者和所属组的用户对文件的权限。以下是其他权限的字符表示:
- r(读取):允许其他用户读取文件内容或查看目录内容。
- w(写入):允许其他用户修改文件内容或在目录中创建、删除文件。
- x(执行):对于文件,允许其他用户执行文件;对于目录,允许其他用户进入该目录。
- -(无权限):表示没有相应的权限。
3、设置文件权限
要设置文件权限,可以使用 chmod 命令。chmod 命令允许用户更改文件的权限设置。用户可以通过两种方式来指定权限设置:权限符号表示法和权限数字表示法。
3.1、chmod 命令
chmod 命令的基本语法如下:
chmod [选项] 权限 文件
其中,权限可以使用权限符号表示法或权限数字表示法。
3.2、权限符号表示法
权限符号表示法使用符号来指定权限设置。以下是常用的权限符号表示法:
- +:添加权限。
- -:移除权限。
- =:设置权限。
使用权限符号表示法时,可以将符号与权限字符组合使用。例如,要为文件所有者添加写入权限,可以运行以下命令:
chmod u+w 文件名
这将为文件所有者添加写入权限。
可以使用以下符号来表示不同的权限:
- u:文件所有者。
- g:文件所属组。
- o:其他用户。
- a:所有用户(包括所有者、所属组和其他用户)。
例如,要为文件所有者和文件所属组添加读取和写入权限,可以运行以下命令:
chmod ug+rw 文件名
这将为文件所有者和文件所属组添加读取和写入权限。
3.3、权限数字表示法
权限数字表示法使用数字来表示权限设置。每个权限字符都被赋予一个特定的数字值:
- r:4
- w:2
- x:1
- -:0
要设置文件权限,可以将这些数字相加。例如,要为文件所有者设置读取和写入权限,可以运行以下命令:
chmod 6 文件名
这将为文件所有者设置读取和写入权限(4+2=6)。
4、查看文件权限
要查看文件的权限设置,可以使用 ls 命令或 stat 命令。
4.1、ls 命令
ls 命令可以列出文件和目录的详细信息,包括文件权限。要查看文件权限,可以运行以下命令:
ls -l 文件名
这将显示文件的详细信息,包括文件权限。
4.2、stat 命令
stat 命令可以显示文件的详细信息,包括文件权限。要查看文件权限,可以运行以下命令:
stat 文件名
这将显示文件的详细信息,包括文件权限。
5、更改文件所有者和所属组
除了设置文件权限,还可以更改文件的所有者和所属组。
5.1、chown 命令
chown 命令用于更改文件的所有者。要更改文件的所有者,可以运行以下命令:
chown 新所有者 文件名
其中,新所有者可以是用户或用户组。
5.2、chgrp 命令
chgrp 命令用于更改文件的所属组。要更改文件的所属组,可以运行以下命令:
chgrp 新所属组 文件名
其中,新所属组可以是用户组。
6、特殊权限
除了常规的文件权限,Linux 还支持一些特殊权限设置,用于特定的用途。
6.1、粘着位(Sticky Bit)
粘着位是一种特殊权限,适用于目录。当目录的粘着位被设置时,只有目录的所有者和文件的所有者才能删除或重命名目录中的文件。
要设置目录的粘着位,可以运行以下命令:
chmod +t 目录
6.2、设置用户或组的默认权限
在 Linux 中,可以为用户或组设置默认权限,以确保新创建的文件或目录具有特定的权限。
要为用户设置默认权限,可以编辑用户的配置文件 .bashrc 或 .bash_profile,并添加以下行:
umask 权限掩码
其中,权限掩码是一个三位八进制数,用于设置默认权限。例如,要为用户设置默认权限为 644,可以使用权限掩码 022,将以下行添加到用户的配置文件中:
umask 022
同样地,要为组设置默认权限,可以编辑 /etc/profile 文件,并添加以下行:
umask 权限掩码
在这种情况下,所有属于该组的用户将具有相同的默认权限。
7、结论
Linux 文件权限是保护文件和目录安全的重要机制。通过正确设置文件权限,我们可以限制对文件的访问、读取、写入或执行操作。本文详细介绍了文件权限的表示方式,包括用户权限、组权限和其他权限。我们还学习了如何设置文件权限,使用 chmod 命令以及权限符号表示法和权限数字表示法。此外,我们了解了如何查看文件权限,使用 ls 命令和 stat 命令。还介绍了如何更改文件的所有者和所属组,使用 chown 命令和 chgrp 命令。最后,我们还了解了特殊权限,如粘着位和默认权限设置。
掌握文件权限的概念和相关命令对于管理和保护 Linux 系统中的文件和目录至关重要。正确设置文件权限可以确保系统的安全性和稳定性。
相关文章:
Linux:【1】Linux中的文件权限概念和相关命令
Linux:【1】Linux中的文件权限概念和相关命令 1、什么是文件权限?1.1、文件权限的表示方式 2、理解文件权限2.1、用户权限2.2、组权限2.3、其他权限 3、设置文件权限3.1、chmod 命令3.2、权限符号表示法3.3、权限数字表示法 4、查看文件权限4.1、ls 命令…...
JS实用小计
1.如何创建一个数组大小为100,每个值都为0的数组 // 方法一: Array(100).fill(0);// 方法二: // 注: 如果直接使用 map,会出现稀疏数组 Array.from(Array(100), (x) > 0);// 方法二变体: Array.from({ length: 100 }, (x) > 0); 2.如何逆序一个字…...
Android---Bitmap详解
每一个 Android App 中都会使用到 Bitmap,它也是程序中内存消耗的大户,当 Bitmap 使用内存超过可用空间,则会报 OOM。 Bitmap 占用内存分析 Bitmap 用来描述一张图片的长、宽、颜色等信息,可用使用 BitmapFactory 来将某一路径下…...
设计高信度和效度的问卷:关键要点与技巧
设计调查问卷是任何研究过程中至关重要的一部分,无论是出于学术目的还是商业目的。调查是用于收集数据的常用工具,它们可以为消费者行为、意见、客户满意度和其他重要因素提供有价值的见解。然而,调查的可靠性和有效性对于确保收集的数据准确…...
从工厂到社会:探索如何应用设计模式工厂模式
文章目录 🌟 将设计模式工厂模式运用到社会当中🍊 工厂模式在社会中的应用🎉 工厂🎉 餐厅🎉 运输 🍊 工厂模式的优势🎉 代码简洁🎉 扩展性强🎉 便于维护和管理 …...
slice()和splice()用法
前言: slice()和splice()都是JavaScript中数组的方法,但是它们的用法有所不同。接下来让我们详细分析一下他们的不同之处。 slice(): slice()方法返回一个数组的一部分,不会改变原始数组,而是返回一个新数组。 语法…...
基于windows10的pytorch环境部署及yolov8的安装及测试
第一章 pytorch环境部署留念 第一步:下载安装anaconda 官网地址 (也可以到清华大学开源软件镜像站下载:https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/) 我安装的是下面这个,一通下一步就完事儿。 第二步…...
面试算法40:矩阵中的最大矩形
题目 请在一个由0、1组成的矩阵中找出最大的只包含1的矩形并输出它的面积。例如,在图6.6的矩阵中,最大的只包含1的矩阵如阴影部分所示,它的面积是6。 分析 直方图是由排列在同一基线上的相邻柱子组成的图形。由于题目要求矩形中只包含数字…...
was下log4j设置日志不输出问题
was下log4j设置日志不输出问题 WAS 也是用的 commons-logging 日志框架 commons-logging 确定 LogFactory 实现的顺序是 从应用的 META-INF/services/org.apache.commons.logging.LogFactory 中获得 LogFactory 实现从系统环境中获得 org.apache.commons.logging.LogFactory…...
小米14系列, OPPO Find N3安装谷歌服务框架,安装Play商店,Google
10月26号小米发布了新款手机小米14,那么很多大家需求问是否支持谷歌服务框架,是否支持Google Play商店gms。因为毕竟小米公司现在安装的系统是HyperOS澎湃OS。但是我拿到手机之后会发现还是开机初始界面会显示power by android,证明这一点他还是支持安装谷歌,包括最近一段时间发…...
Servlet 与Spring对比!
前言: Spring相关的框架知识,算是目前公司在用的前沿知识了,很重要!! 那么以Spring为基础的框架有几个? 以Spring为基础的框架包括若干模块,其中主要的有Spring Framework、Spring Boot、Spring…...
粤嵌实训医疗项目--day03(Vue + SpringBoot)
往期回顾 粤嵌实训医疗项目day02(Vue SpringBoot)-CSDN博客 粤嵌实训医疗项目--day01(VueSpringBoot)-CSDN博客 目录 一、SpringBoot AOP的使用 二、用户模块-注册功能(文件上传) 三、用户模块-注册实现…...
spark3.3.x处理excel数据
环境: spark3.3.x scala2.12.x 引用: spark-shell --jars spark-excel_2.12-3.3.1_0.18.5.jar 或项目里配置pom.xml <!-- https://mvnrepository.com/artifact/com.crealytics/spark-excel --> <dependency><groupId>com.crealytics</groupId><art…...
哪一个更好?Spring boot还是Node.js
前言 本篇文章有些与众不同,由于我自己手头有些关于这个主题的个人经验,受其启发写出此文。虽然SpringBoot和Node.js服务于很不一样的场景,但是这两个框架共性惊人。其实每种语言都有不计其数的框架,但仅仅一部分是真正卓越的。如…...
AD7321代码SPI接口模数转换连接DAC0832输出verilog
名称:AD7321代码12位ADC,SPI接口模数转换连接DAC0832输出 软件:QuartusII 语言:VHDL 代码功能: 使用VHDL语言编写代码,实现AD7321的控制,将模拟信号转换为数字信号,再经过处理后…...
JavaScript_Pig Game切换当前玩家
const current0El document.getElementById(current--0); const current1El document.getElementById(current--1); if (dice ! 1) {currentScore dice;current0El.textContent currentScore;} else {} });这是我们上个文章写的代码,这个代码明显是有问题的&…...
EtherNet Ip工业RFID读写器与欧姆龙PLC 配置示例说明
一、准备阶段 POE交换机欧姆龙PLC 支持EtherNet Ip协议CX-Programmer 9.5配置软件 二、配置读卡器 1、打开软件 2、选择网卡,如果多网卡的电脑请注意对应所接的网卡,网卡名一般为“Network adapter Realtek PCIe GBE Family” 3、点击“选择网卡”&…...
UE5简化打包大小
UE5.3默认空项目带初学者包的打包后1G多 简化思路: 1.不打包初学者包(或者创建时不包括初学者包,跳过第一条) 导航:ProjectSettings->Project->Packaging->Packaging->Advanced->List of maps to incl…...
ThinkPHP8学习笔记
ThinkPHP8官方文档地址:ThinkPHP官方手册 一、composer换源 1、查看 composer 配置的命令composer config -g -l 2、禁用默认源镜像命令composer config -g secure-http false 3、修改为阿里云镜像源composer config -g repo.packagist composer https://mirror…...
NSSCTF做题第9页(2)
[SWPUCTF 2022 新生赛]ez_1zpop <?php error_reporting(0); class dxg { function fmm() { return "nonono"; } } class lt { public $impohi; public $md51weclome; public $md52to NSS; function __construct() { $this-&…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...
Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误
HTTP 状态码 406 (Not Acceptable) 和 500 (Internal Server Error) 是两类完全不同的错误,它们的含义、原因和解决方法都有显著区别。以下是详细对比: 1. HTTP 406 (Not Acceptable) 含义: 客户端请求的内容类型与服务器支持的内容类型不匹…...
label-studio的使用教程(导入本地路径)
文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...
Zustand 状态管理库:极简而强大的解决方案
Zustand 是一个轻量级、快速和可扩展的状态管理库,特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...
【入坑系列】TiDB 强制索引在不同库下不生效问题
文章目录 背景SQL 优化情况线上SQL运行情况分析怀疑1:执行计划绑定问题?尝试:SHOW WARNINGS 查看警告探索 TiDB 的 USE_INDEX 写法Hint 不生效问题排查解决参考背景 项目中使用 TiDB 数据库,并对 SQL 进行优化了,添加了强制索引。 UAT 环境已经生效,但 PROD 环境强制索…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...
【Web 进阶篇】优雅的接口设计:统一响应、全局异常处理与参数校验
系列回顾: 在上一篇中,我们成功地为应用集成了数据库,并使用 Spring Data JPA 实现了基本的 CRUD API。我们的应用现在能“记忆”数据了!但是,如果你仔细审视那些 API,会发现它们还很“粗糙”:有…...
python爬虫——气象数据爬取
一、导入库与全局配置 python 运行 import json import datetime import time import requests from sqlalchemy import create_engine import csv import pandas as pd作用: 引入数据解析、网络请求、时间处理、数据库操作等所需库。requests:发送 …...
如何配置一个sql server使得其它用户可以通过excel odbc获取数据
要让其他用户通过 Excel 使用 ODBC 连接到 SQL Server 获取数据,你需要完成以下配置步骤: ✅ 一、在 SQL Server 端配置(服务器设置) 1. 启用 TCP/IP 协议 打开 “SQL Server 配置管理器”。导航到:SQL Server 网络配…...
Vue 3 + WebSocket 实战:公司通知实时推送功能详解
📢 Vue 3 WebSocket 实战:公司通知实时推送功能详解 📌 收藏 点赞 关注,项目中要用到推送功能时就不怕找不到了! 实时通知是企业系统中常见的功能,比如:管理员发布通知后,所有用户…...
