linux 有效用户和实际用户的区别 Linux 2010-11-02 14:43:15 阅读133 评论0 字号:大中小 订阅 转载: 今天在看APUE,这两个问题很难理解,GOOGLE 一下,有篇文章总结的不错,看了一下才明白透彻了
由于用户在UNIX 下经常会遇到SUID、SGID 的概念,而且 SUID和SGID 涉及到系统安全,所以用户也比较关心这个问题
关于SUID、 SGID 的问题也经常有人提问,但回答的人一般答得不够详细,加上曾经回答过两个网友的问题,还查了一些资料,决定整理成本文,以供大家参考
限于本人的水平问题,文章中如果有不当之处,请广大网友指正
一、UNIX下关于文件权限的表示方法和解析 SUID 是 Set User ID, SGID 是 Set Group ID的意思
UNIX下可以用ls -l 命令来看到文件的权限
用ls命令所得到的表示法的格式是类似这样的:-rwxr-xr-x
下面解析一下格式所表示的意思
这种表示方法一共有十位: 9 8 7 6 5 4 3 2 1 0 - r w x r - x r - x 第9位表示文件类型,可以为p、d、l、s、c、b和-: p表示命名管道文件 d表示目录文件 l表示符号连接文件 -表示普通文件 s表示socket文件 c表示字符设备文件 b表示块设备文件 第8-6位、5-3位、2-0位分别表示文件所有者的权限,同组用户的权限,其他用户的权限,其形式为rwx: r表示可读,可以读出文件的内容 w表示可写,可以修改文件的内容 x表示可执行,可运行这个程序 没有权限的位置用-表示 例子: ls -l myfile显示为: -rwxr-x--- 1 foo staff 7734 Apr 05 17:07 myfile 表示文件myfile是普通文件,文件的所有者是foo用户,而foo用户属于sta