setuid,setgid的作用

先来看下面的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了

 

你可能感兴趣的:(linux,2010)