哪位高手帮我讲解一下chmod命令中的suid和guid?


http://www.chinaunix.net 作者:zy520fxq   发表于:2006-02-10 15:17:15
【发表评论 】 【查看原文 】 【Solaris讨论区 】【关闭 】

哪位高手帮我讲解一下chmod命令中的suid和guid?查了某些资料我还是不懂,我觉得设不设suid和guid好象没有区别,多谢!


 laoxia 回复于:2003-08-28 09:38:47

有三种权限,OWNER权限,GROUP权限,OTHER 权限(如果不是OWNER,又不在
那个组里,你享受此权限),例如,test是个程序,它的权限如下设置

-rwxr-xr--   1  peter  goodguy         11 Jul 31 19:32 test

假如这个程序中执行中要删除一个OWNER为peter的文件data.txt, 而这个文件的权
限设置是这样的:

-rwx------  1 peter badguy   11 Jul 31 19:33  data.txt

在不设SUID的情况下,peter可以执行这个程序并成功的删除文件,而在goodguy 组
的成员,虽然有对test程序的执行权,但执行中删除不掉data.txt这个文件。WHY?
goodguy组里的人对data.txt无删的权力。

假定设了SUID后,goodguy组里的人再执行这个程序,但此程序运行中遇到权限问题,
就自动被赋与OWNER的权力,则此程序可执行也

SGID差不多,只不过针对组权限而言

系统安全中,SUID是一个不提倡的东西,能不用就不用

************************************************************************

************************************************************************

************************************************************************

一般我们看到的是十位:
后面9位如上老兄所说
第一位表示文件类型
-   是普通文件
b  是块设备文件
c   是字符设备文件
d   是目录文件
L   是符号连接文件
P    是命名管道


 Air_Fish 回复于:2005-12-01 18:37:01

各位大虾,有谁了解chmod XXXX 的用法和含义?

有三种权限,OWNER权限,GROUP权限,OTHER 权限(如果不是OWNER,又不在
那个组里,你享受此权限),例如,test是个程序,它的权限如下设置

-rwxr-xr--   1  peter  goodguy         11 Jul 31 19:32 test

假如这个程序中执行中要删除一个OWNER为peter的文件data.txt, 而这个文件的权
限设置是这样的:

-rwx------  1 peter badguy   11 Jul 31 19:33  data.txt

在不设SUID的情况下,peter可以执行这个程序并成功的删除文件,而在goodguy 组
的成员,虽然有对test程序的执行权,但执行中删除不掉data.txt这个文件。WHY?
goodguy组里的人对data.txt无删的权力。

假定设了SUID后,goodguy组里的人再执行这个程序,但此程序运行中遇到权限问题,
就自动被赋与OWNER的权力,则此程序可执行也

SGID差不多,只不过针对组权限而言

系统安全中,SUID是一个不提倡的东西,能不用就不用

_____________________________________________

上面要是和chmod XXXX 设置文件的s权限来说我就很明白了。
[root@mailhost tmp]# touch ok
[root@mailhost tmp]# chmod 6751 ok
-rwsr-s--x    1 root     root            0 Dec  1 18:32 ok
[root@mailhost tmp]# chmod 7457  ok
-r-Sr-srwt    1 root     root            0 Dec  1 18:32 ok

上面文件权限中的s 和 S 是怎么回事,请知道的吗?


 jason0127 回复于:2005-12-02 14:31:35

楼主是高人啊~~~~

[ 本帖最后由 jason0127 于 2005-12-2 14:33 编辑  ]


 饮鸩止渴 回复于:2005-12-02 14:49:52

239的file permission里边讲的很清楚


 caicheng 回复于:2005-12-21 19:29:17

谢谢laoxia这么清楚的讲解。


 ancharn 回复于:2006-02-10 15:17:15

suid/sgid
  
suid/sgid要了解 suid/sgid, 必需先了解 process 及 permission. 我們需知道: 每 個 process 都有其 effective uid/gid , 以決定其在傳統 unix filesystem 中獲得的實 際 permission . 再, process 是由 binary 產生的, 而 binary 是 從 shell / shell script 載入執行. 在正常的情況下, process 的 effective uid/gid 是 從 parent 繼承, 或簡單說是與 shell 的 uid/gid 一樣. shell 的 uid/gid 則是跟據 /etc /passwd 的第 3 與 第 4 欄位決定. 當我們有了以上的概念之後, 再來看 suid 對 effective uid/gid 的影 響: 若 binary file 帶有 suid/sgid 的時候, 其 effective id 就不是從 parent 那邊繼承, 而是 以 binary file 本身的 user/group 為準. 舉例而言, 若一個 prog1 的 user/group 都 是 root , 但沒設 suid/sgid , 那當一個 uid(500)/gid(500) 的 parent process 執行這 個 prog1 的話, 那 effective uid/gid 就是 500 ... 但若 prog1 設了 suid/sgid 後, 那 其 effective uid/gid 就是 root ! 一旦這個 process effective 是 root 的話, 那它 對 file system 的 permission 就如脫繮野馬般任意奔騰而不受限制了. 因此我才在前面提到木馬程式與病毒的例子... 試想一 下: 若病毒的 user/group 被設為 root, 然後被一般 user 執行時, suid/sgid 的有與無將導致甚麼不同結果? 好 了, 由於 suid/sgid 在系統上有其存在的必要性(舉 /usr/bin/passwd 與 /etc/shadow 為例), 但同時又有極 大的殺傷力, 在應用上要異常小心! 因此, bash shell script 在先天上不支援 suid/sgid 而/bin/zsh是支持 suid和sgid的 . perl 亦如此, 除非額外再安裝 suid-perl .... 
 
 
根据现在的Unix机里,脚本是无法设置suid的,因为真正运行的进程是脚本的解释程序而不是脚本本身
当然,理论上可以让脚本的解释程序获得脚本的suid状态并且动态的改变自己的suid属性,然后在脚本运行完毕后再改回去。不过这样的整个系统 架构的修改可以说不算小,而且也不符合POSIX规范(POSIX规范中没有允许一个正在运行的进程动态修改自身的suid属性)

由于SUID和SGID是在执行程序(程序的可执行位被设置)时起作用,而可执 行位只对普通文件和目录文件有意义,所以设置其他种类文件的 SUID和SGID位是 没有多大意义的。 首先讲普通文件的SUID和SGID的作用。例子: 如果普通文件myfile是属于foo用户的,是可执行 的,现在没设SUID位,ls命 令显示如下: -rwxr-xr-x 1 foo staff 7734 Apr 05 17:07 myfile 任 何用户都可以执行这个程序。UNIX的内核是根据什么来确定一个进程对资 源的访问权限的呢?是这个进程的运行用户的(有效)ID,包括user id和 group id。用户可以用id命令来查到自己的或其他用户的user id和group id。 除了一般的user id 和group id外, 还有两个称之为effective 的id,就是 有效id,上面的四个id表示为:uid,gid,euid,egid。内核主要是根据euid 和 egid来确定进程对资源的访问权限。 一个进程如果没有SUID或SGID位,则euid=uid egid=gid,分别是运行这个程 序的用户 的uid和gid。例如kevin用户的uid和gid分别为204和202,foo用户的ui d和gid为200,201,kevin运行 myfile程序形成的进程的euid=uid=204,egid=gid =202,内核根据这些值来判断进程对资源访问的限制,其实就是kevin用 户对资源 访问的权限,和foo没关系。 如果一个程序设置了SUID,则euid和egid变成被运行的程序的所有者的uid和 gid,例如 kevin用户运行myfile,euid=200,egid=201,uid=204,gid=202,则 这个进程具有它的属主foo的资源访问权 限。 SUID的作用就是这样:让本来没有相应权限的用户运行这个程序时,可以访 问他没有权限访问的资源。passwd就是一个很鲜明的例 子。 SUID的优先级比SGID高,当一个可执行程序设置了SUID,则SGID会自动变成 相应的egid。 下面讨论一个例子: UNIX系统有一 个/dev/kmem的设备文件,是一个字符设备文件,里面存储了核 心程序要访问的数据,包括用户的口令。所以这个文件不能给一般的用户读写, 权限设 为:cr--r----- 1 root system 2, 1 May 25 1998 kmem 但ps等程序要读这个文件,而ps的权限设置如 下: -r-xr-sr-x 1 bin system 59346 Apr 05 1998 ps 这是一个设置了SGID的程序,而ps的用户是 bin,不是root,所以不能设置SUID来 访问kmem,但大家注意了,bin和root都属于system组,而且ps设置了SGID,一般 用 户执行ps,就会获得system组用户的权限,而文件kmem的同组用户的权限是可 读,所以一般用户执行ps就没问题了。但有些人说,为什么不把ps 程序设置为 root用户的程序,然后设置SUID位,不也行吗?这的确可以解决问题,但实际中 为什么不这样做呢?因为SGID的风险比SUID小得 多,所以出于系统安全的考虑, 应该尽量用SGID代替SUID的程序,如果可能的话。 下面来说明一下SGID对目录的影响。SUID对目录没有影 响。 如果一个目录设置了SGID位,那么如果任何一个用户对这个目录有写权限的 话,他在这个目录所建立的文件的组都会自动转为这个目录的属主所在的 组,而 文件所有者不变,还是属于建立这个文件的用户

chmod命令中的suid和guid?相关推荐

  1. linux中chmod -r权限,unix及linux中chmod命令的十个例子

    在unix以及linux之中,chmod命令用来改变文件以及目录的权限.这是unix和linux用户所必须熟知众多基本的命令之一.在这个unix命令的教程之中,我们将会学习到如何使用chmod命令来改 ...

  2. linux用命令设置读权限,linux中的文件权限和chmod命令的使用

    1.linux中的文件权限 linux中用ls -al列出文件列表时,会看到第一列有rwx这样的字样,这个表示该文件的权限设置属性.在linux中,权限划分主要分为三种身份:所有者(owner或者us ...

  3. linux命令chmod如果当前用户属于多个组,那这个命令中的g指的是哪个组?按什么规则?

    linux命令chmod如果当前用户属于多个组,那这个命令中的g指的是哪个组?按什么规则? 比如这种命令 chmod u=rwx,g=rw,o=r /home/test1 主用户组,即id命令显示的g ...

  4. php chmod 777 chown,linux命令中chown与chmod的区别

    chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户ID:组可以是组名或者组ID:文件是以空格分开的要改变权限的文件列表,支持通配符.系统管理员经常使用chown命令,在将文件拷贝 ...

  5. linux chmod 777 dev,linux命令中chmod 777 以及drwxr-xr-x分别代表什么意思

    最近跟一个运维人员学了点新东西,感觉以前没怎么注意,但现在感觉很有用,特来记录一下. linux使用ll命令列出列表的时候,前面总是有一堆drwxr-xr-x ,这些代表什么意思从来还没有去在意过,只 ...

  6. chmod命令用法(linux中chmod命令用法)

    linuxsort命令有哪些用法? txt apple banana orange pear 2 sort的-u选项 它的作用很简单,就是在输出行中去除重复行. [rocrocket@rocrocke ...

  7. linux中的chmod命令详细介绍、使用及实例

    linux中的chmod命令详细介绍.使用及实例 chmod命令 chmod用于改变 linux 系统文件或目录的访问权限,可以用它控制文件或目录的访问权限.该命令有两种用法:一种是包含字母的文字设定 ...

  8. linux中文件权限 组,linux中文件权限格式与chmod命令以及用户和用户组的管理

    简单了解一下linux中的文件权限格式与chmod命令 chmod命令:改变文件或者目录的权限 格式:chmod [参数] [] -R 或者--recursive 递归处理,表示将指定目录下的所有文件 ...

  9. linux中chmod命令的用法,【linux】chmod命令详细用法

    功能说明: 变更文件或目录的权限 u:User,即文件或目录的拥有者. g:Group,即文件或目录的所属群组. o:Other,除了文件或目录拥有者或所属群组之外,其他用户皆属于这个范围. a:Al ...

最新文章

  1. DS博客作业04--树大作业
  2. 【转】C#基础概念之“什么是反射?”
  3. silverlight bing maps sdk MapControl Sdk
  4. web中常见乱码问题详解
  5. 《JavaScript高级程序设计》读书笔记 ---if语句
  6. Java EE重新审视设计模式:异步
  7. linux系统下替换图片,Linux(ubuntu系统)下使用FreeImage库
  8. java运行win10_win10配置java运行环境
  9. 字节跳动AI-Lab算法实习生-敏感文字方向
  10. SuSe防火墙iptables配置
  11. supervisor 启动ElasticSearch报错问题
  12. 数据结构-栈操作-用链表实现栈基本操作
  13. pdf介绍及pdf相关软件(内容来自百度百科)
  14. uniapp编译支付宝小程序图片图标显示问题
  15. 认识 ESP-IDF-v4.3+工程结构(ESP32-C3应用调整示例)
  16. 论文笔记-2019-ImageNet-trained CNNs are biased towards texture; increasing shape bias improves accuracy
  17. 2021-07-23 N卡显示器亮度设置
  18. 盘一盘 Python 系列 - Cufflinks (下)
  19. openwrt 自启动实现4G路由器功能总结
  20. 揭秘《超能陆战队》诞生记

热门文章

  1. 网络服务-VSFTP
  2. ipmi重启_重启ipmi服务器
  3. 计算机应用基础win7作业3答案,电大: 国开计算机应用基础(WIN7)形成性考核册3答案.docx...
  4. python中如何在写文件之前删除文件内容_Python:文件的读取、创建、追加、删除、清空...
  5. python经典例题图形_Python 入门经典100实例:实例23 菱形
  6. php两个按钮左右怎么做,css布局两个button在同父标签中左右两侧分布的方法
  7. java8 无符号_Java8包装类 新增 无符号运算方法
  8. 定义一个Address 类(java)
  9. mybatis mysql cursor_MySQL JDBC/MyBatis Stream方式读取SELECT超大结果集
  10. face detection[PyramidBox]