详解linux用户标识UID与有效用户标识EUID

发布时间:2019-10-02编辑:脚本学堂
本文详细介绍了,Linux系统中的用户标识UID与有效用户标识EUID,介绍了二者的异同,有需要的朋友参考下。

本节内容:
linux用户标识UID与有效用户标识EUID

在linux系统中每个进程都有2个ID,分别为用户ID和有效用户ID,UID一般表示进程的创建者(属于哪个用户创建),而EUID表示进程对于文件和资源的访问权限(具备等同于哪个用户的权限)。可以通过函数getuid()和geteuid()或者进程的两个ID值。

当一个用户登陆系统时,系统会将UID和EUID都赋值为/etc/passwd文件中的UID,一般情况下2个ID是相同的,但是某些情况下会出现2个ID不同的情况。

以下通过一个典型问题和代码实例来说明UID和EUID的问题。

一,linux的passwd命令
passwd命令是用来修改用户登陆密码的,用来记录用户登陆密码的文件为/etc/shadow,该文件只有root用户具有访问权限,如下所示:
 

复制代码 代码示例:
zth@jb200.com:~$
zth@jb200.com:~$ cd /etc
zth@jb200.com:/etc$ ls -l shadow
-rw-r----- 1 root shadow 978 2009-02-22 21:25 shadow
zth@jb200.com:/etc$
 

出于安全考虑,不允许普通用户查看并修改shadow文件;但是如果这样普通用户就无法为自己修改密码。

Linux系统就是使用setuid来解决这个矛盾的问题:如果一个程序被设置了setuid位,那么它无论被哪个用户启用,都会具备程序所有者的权限。

而passwd程序的所有者是root用户,passwd的权限如下所示,那么任何用户执行该程序,程序的EUID就会变成root用户的 EUID,而不是执行该程序的UID。
 

复制代码 代码示例:
zth@jb200.com:/etc$ cd /usr/bin
zth@jb200.com:/usr/bin$ ls -l passwd
-rwsr-xr-x 1 root root 32988 2008-06-10 02:10 passwd
zth@jb200.com:/usr/bin$
zth@jb200.com:/usr/bin$
 

因此,普通用户可以通过passwd程序修改shadow文件内容,完成密码修改。

参考代码:
 

复制代码 代码示例:

#include
#include
#include

int main(void)
{
printf("Current process UID: %ldn",(long)getuid());
printf("Current process EUID: %ldn",(long)geteuid());
return 1;
}

执行情况:
 

复制代码 代码示例:
zth@jb200.com:~$ gcc -o uid uid.c
zth@jb200.com:~$
zth@jb200.com:~$ chmod u+s uid //用户主增加权限setuid
zth@jb200.com:~$ ls -l uid
-rwsr-xr-x 1 gaolu gaolu 9118 2009-03-08 22:26 uid
zth@jb200.com:~$
zth@jb200.com:~$ ./uid
Current process UID: 1000
Current process EUID: 1000
zth@jb200.com:~$
zth@jb200.com:~$ su //切换到root用户
Password:
root@jb200.com:/home/gaolu# ls -l uid
-rwsr-xr-x 1 gaolu gaolu 9118 2009-03-08 22:26 uid
root@jb200.com:/home/gaolu# ./uid
Current process UID: 0
Current process EUID: 1000 //有效用户ID为1000
root@jb200.com:/home/gaolu#
root@jb200.com:/home/gaolu#