文件权限 SUID SGID SBIT 数字转换

2023-12-13 10:58
文章标签 转换 权限 数字 sgid suid sbit

本文主要是介绍文件权限 SUID SGID SBIT 数字转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SUID

SUID是指一种对二进制程序进行设置的特殊权限,可以让二进制程序的执行者临时拥有属主的权限,仅对拥有执行权限的二进制程序有效。
在这里插入图片描述
查看passwd命令属性时发现所有者的权限由rwx变成了rws,其中x变成了s就意味着该文件被赋予了SUID权限。另外,如果文件原本的权限是rw-,没有可执行权限,则被赋予SIUD权限后就会变成大写S。

,,

SGID

SGID主要实现如下功能:
1.让执行者临时拥有属组的权限(对拥有执行权限的二进制程序进行设置)
2.在某个目录中创建的文件自动继承该目录的用户组(只可以对目录进行设置)

SGID的第一种功能是参考SUID而设计的,不同点是在于执行程序的用户获取的不再是文件所有者的临时权限。例如:ps命令文件的属性信息。它的文件权限为 r-xr-sr-x ,注意,由于ps命令文件被增加了SGID特殊服务权限位,所以当用户执行该命令时,也就临时获取到了该用户组的权限,从而可以顺利的读取设备文件了。
SGID的第二种功能。每个文件都会有自己的所有者和所属组,当创建或传送一个文件后,此文件则会自动归属于执行这个操作的用户,即该用户就是该文件的所有者。

如图:
在这里插入图片描述
我们在root用户下切换到tmp目录下,然后创建一个目录testdir,并且用chmod命令设置SGID权限。然后切换到另一个普通用户dkl,尝试在该目录下创建文件test,并查看新创建的文件是否会继承文件所在的目录的所属组的名称,如图中红色标记,不会的,这变时SGID的第二个功能。

SBIT

SBIT特殊权限可以确保用户只能删除自己的文件,而不能删除其他用户的文件。也就是说,当对某个目录设置了SBIT权限位以后,那么该目录中的文件就只能被其所有者执行删除操作了。
与之前SUID和SGID权限的显示方法不同,当目录被设置了SBIT权限位后,文件的其他人权限部分的x执行权限会被替换成t或T,原本有执行权限x则被替换成t,没有执执行权限-则被替换成T。
如图所示:
在这里插入图片描述

数字转换

文件的读 写 执行权限可以简写为r,w,x(read,write,execute),分别可以用数字4,2,1来表示。

如图:
在这里插入图片描述
图中的文件123.txt权限为 rwxr-xr-x
用数字翻译过来就是755

对于特殊权限下面举俩个例子:

  1. 比如rwsrwSrwT 转换成数字就是7766.
    思路就是先写成 rwxrw-rw- ,对应的766 ,而该文件具有特殊权限位SUID,SGID,SBIT,并且这三个权限位对应的数字分别是4,2,1,所以在766前面写数字和4+2+1=7,即7766 。

  2. 再比如7654 转换成字符就是rwSr-sr-T
    思路就是先看654,即420401400,即rw-r-xr–
    最前面的7则说明三个特殊权限都有4+2+1,所以在rw-r-xr–的基础上改一下,有执行操作的写成s或者t,没有执行操作的写成S或者T,所以最后的结果就是
    rwSr-sr-t

这篇关于文件权限 SUID SGID SBIT 数字转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/488207

相关文章

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

AIGC6: 走进腾讯数字盛会

图中是一个程序员,去参加一个技术盛会。AI大潮下,五颜六色,各种不确定。 背景 AI对各行各业的冲击越来越大,身处职场的我也能清晰的感受到。 我所在的行业为全球客服外包行业。 业务模式为: 为国际跨境公司提供不同地区不同语言的客服外包解决方案,除了人力,还有软件系统。 软件系统主要是提供了客服跟客人的渠道沟通和工单管理,内部管理跟甲方的合同对接,绩效评估,BI数据透视。 客服跟客人

Golang进程权限调度包runtime

关于 runtime 包几个方法: Gosched:让当前线程让出 cpu 以让其它线程运行,它不会挂起当前线程,因此当前线程未来会继续执行GOMAXPROCS:设置最大的可同时使用的 CPU 核数Goexit:退出当前 goroutine(但是defer语句会照常执行)NumGoroutine:返回正在执行和排队的任务总数GOOS:目标操作系统NumCPU:返回当前系统的 CPU 核数量 p

android java.io.IOException: open failed: ENOENT (No such file or directory)-api23+权限受权

问题描述 在安卓上,清单明明已经受权了读写文件权限,但偏偏就是创建不了目录和文件 调用mkdirs()总是返回false. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/><uses-permission android:name="android.permission.READ_E

Android6.0以上权限申请

说明: 部分1:出自:http://jijiaxin89.com/2015/08/30/Android-s-Runtime-Permission/ android M 的名字官方刚发布不久,最终正式版即将来临! android在不断发展,最近的更新 M 非常不同,一些主要的变化例如运行时权限将有颠覆性影响。惊讶的是android社区鲜有谈论这事儿,尽管这事很重要或许在不远的将来会引

数据流与Bitmap之间相互转换

把获得的数据流转换成一副图片(Bitmap) 其原理就是把获得倒的数据流序列化到内存中,然后经过加工,在把数据从内存中反序列化出来就行了。 难点就是在如何实现加工。因为Bitmap有一个专有的格式,我们常称这个格式为数据头。加工的过程就是要把这个数据头与我们之前获得的数据流合并起来。(也就是要把这个头加入到我们之前获得的数据流的前面)      那么这个头是