【Linux】用户组、用户、文件权限(ugo权限),权限掩码,chmod,chown,suid,sgid,sticky,su,sudo

news2025/1/16 2:46:22

用户组

注意:普通用户只能查看有哪些组,不能创建/修改/删除,会提示:用户名 is not in the sudoers file.This incident will be reported.

groupadd 用户组名新建用户组
cat /etc/group查看有哪些组(普通用户可以操作)
groupmod -n 新组名 旧组名修改组名
groupdel 用户组名删除用户组


用户

创建用户时:

  1. 为用户创建家目录和邮箱文件,家目录名和邮箱文件名都与用户名相同。家目录在/home目录下,若修改用户名,家目录名不会修改。邮箱文件在/var/spool/mail目录下,若修改用户名,邮箱名会自动修改。
  2. 若没有指定组,会创建组,组名与用户名相同。
  3. 将用户名、密码和组,分别记录在/etc/passwd、/etc/shadow、/etc/group中。

删除用户时:

  • 使用-r,则删除用户时,也删除相关联的文件。
  • 若没有使用-r,则只删除/etc/passwd、/etc/shadow里的记录,不会删除家目录、邮箱文件。重新创建该用户,会提示"the home directory already exists,creating mail file:file exists",可以手动删除家目录和邮箱文件,再创建用户。

普通用户只能查看有哪些用户和修改自己的密码,其他操作几乎都没有权限。

useradd 用户名新建用户
useradd -g 组名 用户名新建用户时指定组
passwd 用户名给用户设置密码
passwd用户修改自己的密码(普通用户可以操作)密码限制比较多
id 用户名查看是否有某用户(普通用户可以操作)
cat /etc/passwd查看有哪些用户(普通用户可以操作)
cat /etc/shadow/etc/shadow:存放用户密码的文件
usermod -l 新用户名 用户名修改用户名,-l(小写字母l)
usermod -u 新id 用户名修改用户id
usermod -g 新组名 用户名修改用户所属组
usermod -G 新附加组名 用户名修改用户所属的附加组
usermod -d 目标路径 用户名修改用户登录后的默认目录
usermod -L 用户名锁定某用户密码
usermod -U 用户名解除密码锁定
lchage -l 用户名查看用户状态,-l(小写字母l)
userdel 用户名删除用户
userdel -r 用户名删除用户及其关联文件

 


文件权限(ugo权限)

通过 ls -l 或者 ll 查询到的以详细信息显示的目录下所有文件,最前面信息就是各文件的权限。文件权限,又称为ugo权限。

# 查看当前目录下所有文件的权限
ls -l
ll

从左向右前10个字符依次说明: 

  • 第1个字符是文件类型: - 文件,d 目录,l 软链接(类似Windows中的快捷方式)。
  • 接下来3个字符是文件所属用户的权限,即user,简写u。
  • 再接下来3个字符是文件所属组的权限,即group,简写g。
  • 最后3个字符是其他组用户的权限,即other,简写o。
  • 权限:3个字符,依次为r(读),w(写),x(可执行),若没有某权限,则为 -(没有某权限,取决于字符位置)。
权限说明权限值文件权限说明目录权限说明说明
rread,读4可以读取文件内容可以查看目录下有哪些文件若为-,则没有读权限
wwrite,写2可以往文件写入内容可以在目录下创建/修改/删除文件若为-,则没有写权限
xexecute,可执行1可以执行文件可以使用cd切换到该目录若为-,则没有可执行权限
权限值表
0---
1--x
2-w-
3-wx
4r--
5r-x
6rw-
7rwx

 


 权限掩码:创建文件或目录时,屏蔽的默认权限。是一个3位的八进制数字。

  • root 默认权限掩码是022(即所属组的写权限,其他用户的写权限),即root创建的文件或目录,所属组和其他用户的写权限都被屏蔽了。
  • 普通用户默认权限掩码是002(即其他用户的写权限),即普通用户创建的文件或目录,其他用户的写权限被屏蔽了。

文件的初始权限值=0666-权限掩码值。目录的初始权限值=0777-权限掩码值。

  • root用户,文件的初始权限值是644(即-rw-r--r--),目录的初始权限值是755(即drwxr-xr-x)。
  • 普通用户,文件的初始权限值是664(即-rw-rw-r--),目录的初始权限值是775(即drwxrwxr-x)。
# 查询权限掩码值
umask

可在/etc/profile修改权限掩码,但只有root有权限。 


chmod命令(change mode):控制用户对文件的权限。

用户:u 所属用户,g 所属组, o 其他用户,a 或者 ugo 所有用户。

操作:+ 添加权限,- 取消权限。

权限:r 读权限,w 写权限,x 可执行权限。

# 给所属组(g)添加写权限(w)
chmod g+w 文件名或目录名

# 给所属组(g)取消写权限(w)
chmod g-w 文件名或目录名

# 给所属组(g)和其他用户(o)添加可执行权限(x)
chmod g+x,o+x 文件名或目录名

# 给所属组(g)和其他用户(g)取消可执行权限(x)
chmod go-x 文件名或目录名

# 当前目录和子目录下所有文件,给所有用户添加读权限(r)
chmod -R a+r *

也可以使用数字表示权限。

# 755:依次为所属用户权限-所有(rwx),所属组权限-可读可执行(r-x),其他用户权限-可读可执行(r-x)
chmod 755 文件名或目录名


chown命令(change owner):修改文件的用户或组。

注意:chown命令需要root权限才能执行。指定的用户或组可以使用用户名或用户id,组名或组id。

# 修改文件的所属用户(使用 用户名)
chown 新用户名 文件名或目录名

# 修改文件的所属组(使用 组id)
chown :新组名id 文件名或目录名

# 修改文件的所属用户和组
chown 新用户名:新组名 文件名或目录名

# 修改当前目录和子目录下所有文件的所属用户和所属组
chown -R 新用户名:新组名 *


suid(set  owner user id up on execution):特殊的文件权限,暂时给予使用者所属用户的权限。

设置suid,就是在文件执行过程中,将所属用户的权限和id 给予使用者。所有用户都可以暂时以文件所属用户的身份执行文件。

只能二进制文件设置suid,设置在所属用户可执行权限位,一般用于需要root权限的命令

在查看目录下文件详细信息时,文件权限的所属用户可执行权限位一般是x(可执行) 或 - (没有可执行权限),若为s(小写s)则设置了suid,则所有用户都可以暂时以文件所属用户的身份执行文件。若为S(大写s)则权限无效(即所属用户没有执行权限)。

使用chmod命令设置或取消suid(u-s:取消。u+s:添加)。也可以使用数字设置或取消suid(0:取消。4:添加suid),使用数字需小心。

# 设置suid
chmod u+s 文件名

# 取消suid
chmod u-s 文件名

# 设置suid(4:添加suid)
# 755:依次为所属用户权限-所有(rwx),所属组权限-可读可执行(r-x),其他用户权限-可读可执行(r-x)
chmod 4755 文件名

# 取消suid(0:取消suid)
chmod 0755 文件名


sgid(set group id):特殊的文件权限,给予使用者所属组的权限。

目录(文件夹)设置sgid,设置在所属组可执行权限位,一般用于共享目录(文件夹)

在查看目录下文件详细信息时,文件权限中所属组可执行权限位一般是x(可执行) 或 - (没有可执行权限),但若是s(小写s),则该目录下,所有用户创建的文件的所属组都与目录的所属组相同。若为S(大写s),则权限无效(即所属组没有执行权限)。

  使用chmod命令设置或取消sgid(g-s:取消。g+s:添加)。也可以使用数字设置或取消sgid(0:取消。2:添加sgid),使用数字需小心。

注意:若sgid和sticky都设置时,若使用数字取消sgid,可能sgid没取消,反而把sticky取消。

# 添加sgid
chmod g+s 目录名

# 取消sgid
chmod g-s 目录名

# 添加sgid(2:添加)
# 777:依次为所属用户权限-所有(rwx),所属组权限-所有(rwx),其他用户权限-所有(rwx)
chmod 2755 目录名

# 取消sgid(0:取消)
chmod 0755 目录名


sticky(sticky bit):粘滞位。特殊的文件权限,普通用户只能删除自己的文件。

目录(文件夹)设置sticky,设置在其他用户可执行权限位,一般用于公共目录(文件夹)

在查看文件详细信息时,文件权限中其他用户可执行权限位一般是x(可执行) 或 - (没有可执行权限),但若是t,则该目录下,目录所属用户和root可以删除该目录下的文件,普通用户只能删除自己创建的,不能删除其他用户创建的。若是T,则权限无效(即其他用户没有执行权限)。

 使用chmod命令设置或取消sticky(o-t:取消,o+t:添加)。也可以使用数字设置或取消sticky(0:取消,1:添加sticky),使用数字需小心。

# 添加sticky
chmod o+t 目录名

# 取消sticky
chmod o-t 目录名

# 添加sticky(1:添加)
# 777:依次为所属用户权限-所有(rwx),所属组权限-所有(rwx),其他用户权限-所有(rwx)
chmod 1777 目录名

# 取消sticky(0:取消)
chmod 0777 目录名

 


su 命令(switch user): 普通用户和root之间切换。

普通用户和root之间可以进行切换。但普通用户切换到root,需要root密码。而root可以直接切换到普通用户。

普通用户和root之间切换
whoami显示当前用户
su - root

普通用户切换到root用户

(普通用户可以操作,需输入root密码)

效果等同于 su - 
su 普通用户名

root用户切换到普通用户,当前目录也切换到普通用户的家目录

(无需密码)

su 普通用户名

root用户切换到普通用户,当前目录不会切换

(无需密码)

exit返回原用户

 


sudo命令(superuser do):root授权一部分权限给普通用户。 

root授权一部分权限给普通用户,普通用户登录自己的账号通过"sudo 命令"使用root身份执行命令,而不需要root密码。

/etc/sudoers配置文件(记录授权用户和权限),只有root能修改。 使用visudo可直接修改配置文件。

# vi/vim修改配置文件
vi /etc/sudoers

# 直接修改配置文件
visudo

若被授权,普通用户可以登录自己的账号,使用sudo执行命令(需输入自己的密码)。

若没有被授权,则提示用户不在sudoers配置文件中。

# 查看自己的权限(执行sudo的使用者)
sudo -l


Linux中“一切皆文件”,文件权限设置时,需慎重。

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

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

相关文章

python模拟QQ聊天的代码

以下是一个简单的Python模拟QQ聊天的代码示例: python # 导入QQ消息包 import tqq # 创建QQ客户端对象 client tqq.TQQClient() # 连接QQ服务器 client.connect("你的QQ号码", "你的QQ密码") # 创建一个QQ会话对象 session client.session() …

字符串函数(二):strlen(求长度),strstr(查找子串),strtok(分割),strerror(打印错误信息)

字符串函数 一.strlen(求字符串长度)1.函数使用2.模拟实现(三种方法) 二.strstr(字符串查找子串)1.函数使用2.模拟实现 三.strtok(字符串分割)四.strerror,perror&#x…

BLDC电机基础知识

1、电机工作原理 电机输入的是电能输出机械能,即电机是一种将电能转换为机械能的装置。电机利用磁场的同名磁极互相排斥以及电磁场原理完成电能与机械能的转换。 由物理电磁场理论知识我们知道,磁铁周围存在磁场,同时运动的电荷或通电导线周…

【强训笔记】day22

NO.1 思路&#xff1a;将情况全部枚举出来。 代码实现&#xff1a; #include <iostream> #include<string> using namespace std;string a,b; int main() {cin>>a>>b;int ma.size(),nb.size();int retm;for(int i0;i<n-m;i){int tmp0;for(int j…

Linux修改终端命令颜色

1.在家目录中修改.bashrc文件 cd ~ vim .bashrc2.找到PS1相关段落&#xff0c;把其他的注释掉&#xff0c;填上该行代码&#xff0c;修改为自己设置的颜色 (具体颜色查看参考文章) 提供两种颜色&#xff0c;其他的自学调色盘吧(下文有)~ (祝你愉快) ①浅蓝色 深蓝 PS1\[\03…

知识图谱 | 语义网络写入图形数据库(含jdk和neo4j的安装过程)

Hi&#xff0c;大家好&#xff0c;我是半亩花海。本文主要介绍如何使用 Neo4j 图数据库呈现语义网络&#xff0c;并通过 Python 将语义网络的数据写入数据库。具体步骤包括识别知识中的节点和关系&#xff0c;将其转化为图数据库的节点和边&#xff0c;最后通过代码实现数据的写…

pytorch学习(一):tensorboard使用

第一次使用需要加入 pip install tensorboard安装后&#xff0c;就可以使用tensorboard&#xff1b; from torch.utils.tensorboard import SummaryWriterwriterSummaryWriter("logs")# writer.add_image() for i in range(100):writer.add_scalar("yx",…

JWT令牌技术实现登录校验

一.简单登录功能 在登录界面中&#xff0c;我们可以输入用户的用户名以及密码&#xff0c;然后点击 "登录" 按钮就要请求服务器&#xff0c;服务端判断用户输入的用户名或者密码是否正确。如果正确&#xff0c;则返回成功结果&#xff0c;跳转至系统首页面。 1.功能…

LeetCode1657确定两个字符串是否接近

题目描述 如果可以使用以下操作从一个字符串得到另一个字符串&#xff0c;则认为两个字符串 接近 &#xff1a; 操作 1&#xff1a;交换任意两个 现有 字符。例如&#xff0c;abcde -> aecdb操作 2&#xff1a;将一个 现有 字符的每次出现转换为另一个 现有 字符&#xff0…

智慧公厕系统:改变“上厕所”体验的科技革新

公共厕所是城市建设中不可或缺的基础设施&#xff0c;然而&#xff0c;由于较为落后的管理模式&#xff0c;会常常存在着管理不到位、脏乱差的问题。为了改善公厕的使用体验&#xff0c;智慧公厕系统应运而生&#xff0c;并逐渐成为智慧城市建设的重要组成部分。本文将以智慧公…

6. RedHat认证-基于公钥的认证方式

6. RedHat认证-基于公钥的认证方式 主要学习客户端访问服务端的时候&#xff0c;免密登录这一方式 注意: 免密登录只是基于公钥认证的一个附带属性(基于公钥认证的方式更加安全&#xff0c;防止黑客暴力破解) 第一步&#xff1a;将客户端生成的秘钥传送到服务器 在客户端通过…

display:flex align-items:center无效的不一样的解决思路

写H5的时候&#xff0c;希望两个元素在div中垂直居中&#xff0c;但是设置align-items:center无效&#xff0c;最终排查原因是引入三方css影响了align-items:center。 具体分析如下&#xff0c;想让搜索图标和input在div里水平居中&#xff1a; 布局如下&#xff1a; <div…

实验十 智能手机互联网程序设计(微信程序方向)实验报告

实验目的和要求 完成以下页面设计。 二、实验步骤与结果&#xff08;给出对应的代码或运行结果截图&#xff09; Wxml <view class"container"> <view class"header"> <view class"logo"…

MHD093C-058-PG1-AA具备哪些特点?

MHD093C-058-PG1-AA是一种高性能的伺服电机控制器。 该产品具备以下特点&#xff1a; 高精度与高性能&#xff1a;MHD093C-058-PG1-AA设计用于提供精确的运动控制和定位&#xff0c;适用于需要高精度定位和控制的场合。快速响应&#xff1a;采用先进的控制技术&#xff0c;确…

C++类与对象基础探秘系列(二)

目录 类的6个默认成员函数 构造函数 构造函数的概念 构造函数的特性 析构函数 析构函数的概念 析构函数的特性 拷贝构造函数 拷贝构造函数的概念 拷贝构造函数的特性 赋值运算符重载 运算符重载 赋值运算符重载 const成员 const修饰类的成员函数 取地址及const取地址操作…

扫码枪与Input的火花

文章目录 前言一、需求&#xff1a;交互细节二、具体实现两个核心的函数&#xff1a;自动聚焦 三&#xff0c;扩展知识input 与 change的区别 前言 在浏览器扫描条形码获取条形的值&#xff0c;再操作对应的逻辑。这是比较常见的业务&#xff0c;这里记录实际操作。 其中PC端…

LeetCode2095删除链表的中间节点

题目描述 给你一个链表的头节点 head 。删除 链表的 中间节点 &#xff0c;并返回修改后的链表的头节点 head 。长度为 n 链表的中间节点是从头数起第 ⌊n / 2⌋ 个节点&#xff08;下标从 0 开始&#xff09;&#xff0c;其中 ⌊x⌋ 表示小于或等于 x 的最大整数。对于 n 1、…

Leaflet系列——【一】初识Leaflet与Leaflet视图操作

初识Leaflet&#xff08;vue3 &#xff09; 前言&#xff1a;当你熟悉了openlayer、mapbox、cesium等一些GIS框架之后&#xff0c;对于我们开发来说其实他们的本质就是往瓦片上面叠加图层、【点、线、面、瓦片、geoJson、热力图、图片、svg等等】都是一层层的Layer图层&#xf…

AI与人类生活的融合:安克创新CEO阳萌的深度洞见

安克创新CEO阳萌分享了他对人工智能未来发展的深刻见解。阳萌不仅深入探讨了大模型技术的应用前景&#xff0c;还对AI与人类生活的融合提出了引人入胜的思考。以下是对这次访谈内容的总结和分析。 大模型技术的现实应用 阳萌提到&#xff0c;尽管大模型在处理通用知识方面表…

拥有一个生产女朋友的工厂,是什么体验

正所谓&#xff0c;“旱的旱死&#xff0c;涝的涝死”&#xff0c;在这个充满竞争的编程界&#xff0c;我们似乎总是忙于解决bug和优化算法&#xff0c;以至于个人生活常常被忽略。但别担心&#xff0c;今天&#xff0c;我们要用一种独特的方式&#xff0c;解决这个“问题”。 …