Linux中文件特殊权限suid、sgid、sticky详解

ops/2024/10/9 15:17:07/

Linux中文件特殊权限suid、sgid、sticky

作用对象

  • suid权限作用于文件属主
  • sgid权限作用于属组
  • sticky权限作用于other

suid

  • 作用:让普通用户临时拥有该文件的属主的指向权限,suid权限只能应用在二进制可执行文件(命令)
  • 表示方法:
    • 使用s表示,增加权限为u+s,移除权限为u-s
    • 数字形式表示,0表示去除suid权限,4表示添加suid权限,并且要在原权限的数字表达形式开头加0或4,如:0755表示移除suid权限,4755表示添加suid权限
注意:
  • suid仅对二进制文件有效
  • 在执行过程中,调用者会暂时获得该文件的所有者权限
  • 该权限只在程序执行的过程中有效

举例说明

普通用户执行执行passwd命令时需要去修改/etc/shaow等文件,但/etc/shaow发现该文件没有任何权限,即普通用户对/etc/shaow文件是没有写入权限的。但是为什么普通用户可以修改自己密码的呢?答案是因为passwd这个(二进制文件)命令,具有suid权限,可以使得普通用户临时具有root权限,进而使普通用户可以修改自己的密码
[root@localhost ~]# ll /etc/shadow					
#这个文件没有任何权限,只有root超级管理员才能修改
---------- 1 root root 1575 Oct  5 22:48 /etc/shadow
[root@localhost ~]# ll /usr/bin/passwd 
-rwsr-xr-x. 1 root root 27832 Jun 10  2014 /usr/bin/passwd	
#有个suid权限,这就说明了普通用户执行passwd命令时临时提权到root权限了,所以才有root权限才写到shadow文件

suid权限只能应用于二进制可执行文件上

sgid

  • 作用范围
    • 文件:如果SGID设置在二进制文件上,则不论用户是谁,在执行该程序的时候,程序的所属组将会变成该程序文件的所属组。
    • 程序:如果SGID是设置在A目录上,则在A目录内所建立的文件或目录的所属组,将会是此A目录的所属组
  • 注意:一般SGID多用于特定的多人团队的项目开发中,在系统中用的很少

sticky

  • 作用:

    • sticky权限一般针对目录来设置,对文件没有效果,用来限制具有sticky的目录下的文件只能文件的创建者删除自己创建的文件,不允许其它人删除文件

    • 例如:当 student 用户属于 A 目录的组成员或属于 other ,且拥有 wx 权限时, 可以对该目录内任

      何人建立的目录或文件进行“ 删除/重命名/移动” 等操作。 如果将 A 目录加上了 Sticky Bit 权限, 则

      student用户只能针对自己建立的文件或目录进行“ 删除/重命名/移动” 等操作。

  • 表示方法:

    • 使用s表示,增加权限为o+t,移除权限为o-t
    • 数字形式表示,0表示去除sticky权限,1表示添加sticky权限,并且要在原权限的数字表达形式开头加0或1,如:0755表示移除sticky权限,1755表示添加sticky权限

http://www.ppmy.cn/ops/5335.html

相关文章

mac jd-gui安装

在macOS上安装JD-GUI(Java Decompiler GUI)是一个简单的过程。JD-GUI是一个独立的图形化应用程序,你可以使用它来查看Java字节码对应的源代码。下面是安装步骤: 下载JD-GUI: 访问JD-GUI的官方网站(http://j…

C语言入门算法——最大公约数和最小公倍数问题

题目描述: 输入两个正整数 x0​,y0​,求出满足下列条件的 P,Q 的个数: P,Q 是正整数。 要求P,Q 以 x0​ 为最大公约数,以 y0​ 为最小公倍数。 试求:满足条件的所有可能的 P,Q 的个数。 输入格式 一行两个正整数…

使用Python进行自动化测试

👽发现宝藏 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 如何使用Python进行自动化测试:测试框架的选择与应用 自动化测试是软件开发过程…

XiaodiSec day015 Learn Note 小迪渗透学习笔记

XiaodiSec day015 Learn Note 小迪渗透学习笔记 记录得比较凌乱,不尽详细 day15 还是基础的Php开发 看来是比较基础的 主题:登录验证 COOKIE & SESSION 后台系统有多个验证 为了方便验证使用cookie或session 类似于用户状态管理? cookie存储…

cocos creator 3.6 发布web手机端 加载进度条添加

cocos creator 升级到3.x之后加载进度条取消了,测试了多个3.x版本最终以creator 3.6.3版本,构建了简单的进度加载 参考链接: https://forum.cocos.org/t/topic/137113 打包web-mobile后,没有进度条。加载的时候只显示一个黑屏。…

MySQL 列数据跨表拷贝,一句SQL快速将表A每条记录的某些字段拷贝到表B每条记录的某些字段(A、B表通过ID等字段对应)

文章目录 MySQL 列数据跨表拷贝,一句SQL快速将表A每条记录的某些字段拷贝到表B每条记录的某些字段(A、B表通过ID等字段对应)背景定义表填充测试数据跨表一 一对应拷贝列数据SQL参考资料 MySQL 列数据跨表拷贝,一句SQL快速将表A每条…

SpringBoot集成EasyExcel 3.x:高效实现Excel数据的优雅导入与导出

目录 介绍 快速开始 引入依赖 简单导出 定义实体类 自定义转换器 定义接口 测试接口 复杂导出 自定义注解 定义实体类 数据映射与平铺 自定义单元格合并策略 定义接口 测试接口 一对多导出 自定义单元格合并策略 测试数据 简单导入 定义接口 测试接口 参…

【机器学习】机器学习学习笔记 - 数据预处理 - 01

machine learning 监督学习: 是指在有标记的样本(labeled samples)上建立机器学习的模型无监督学习: 是指在没有标记的样本上建立机器学习的模型semi-supervised learning: 是指在部分标记样本上建立机器学习的模型强化学习: 是指在与环境交互的过程中&…