linux实际用户和有效用户的区别,附程序示例说明

来源:互联网 发布:配煤软件 编辑:程序博客网 时间:2024/06/06 07:23

看unix高级编程的时候,第八章有提到实际用户和有效用户,那么这两个用户到底是什么,它们之间有什么区别呢?

实际用户:表示一开始执行程序的用户,比如用账号iceup登录shell,然后执行程序ls,那么实际用户就是iceup。
有效用户:有效用户是指在程序运行时,计算权限的用户。大多数情况下实际用户和有效用户相等,但是在执行拥有SUID权限的程序的时候,这两个用户通常会不一致。

为方便理解,笔者用C写了一个例子hello.c,内容很简单,就是获取实际用户id和有效用户id然后输出,代码如下:

1#include <stdio.h>
2 
3int main(void)
4{
5    int uid, euid;
6    //实际用户id
7    uid = getuid();
8    //有效用户id,其中e表示effective,就是有效的意思
9    euid = geteuid();
10 
11    printf("uid=%d\n", uid);
12    printf("euid=%d\n", euid);
13    return 0;
14}

编译后的执行文件为a.out,使用ls -l查看两个文件的属性:

实际用户和有效用户演示文件属性

实际用户和有效用户演示文件属性

可以看到a.out的所有者为root,用root账号运行这个文件,输出如下:

$ ./a.outuid=0euid=0

换一个账号iceup运行这个文件,输出如下:

$ ./a.outuid=1001euid=1001

这两个执行结果比较显而易见,实际用户和有效用户都是一致的。前面一个执行者是root,所以两个都是0,在linux下root的id就是0;后面一个是1001,就是iceup的编号。

下面来看下实际用户和有效用户不一致的情况,切换回root,修改a.out的权限,增加SUID权限:

$ chmod u+s a.out

使用iceup来执行这个程序,结果输出如下:

$ ./a.outuid=1001euid=0

可以看到有效用户和实际用户不一致了,因为一开始执行程序的是iceup账号,所以实际用户uid=1001。因为a.out有SUID权限,所有在执行的时候,权限的计算会转为root账号,所以有效用户euid=0了。

0 0
原创粉丝点击