先来看下面的code
#include <stdio.h>
int main()
{
printf("pid: %d/n", getpid());
printf("ppid: %d/n", getppid());
printf("uid: %d/n", getuid());
printf("euid: %d/n", geteuid());
printf("gid: %d/n", getgid());
printf("egid: %d/n", getegid());
return 0;
}
这段代码是用来显示当前进程的 进程id,uid, euid, gid, egid的。
正常时,显示如下。
[root@SPSW_Linux_DevTest test]# ll main
-rwxrwxr-x 1 w2 w2 5495 2010-07-27 15:55 main
[w2@92 test]
$./main
pid: 22791
ppid: 4976
uid: 507
euid: 507
gid: 507
egid: 507
可以看到,这时显示的uid == euid, gid == egid.
[root@SPSW_Linux_DevTest test]# chown root:root main
[root@SPSW_Linux_DevTest test]# chmod 6775 main
[root@SPSW_Linux_DevTest test]# ll main
-rwsrwsr-x 1 root root 5495 2010-07-27 15:55 main
好了,这下文件是root的了,也设置了setuid, setgid。
再来运行一下这个程序看看。
[w2@92 test]
$./main
pid: 22846
ppid: 4976
uid: 507
euid: 0
gid: 507
egid: 0
euid != uid, egid != gid了