曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 4398|回复: 0
打印 上一主题 下一主题

[用户与组] getgid()/getegid() -- 获取真实组ID/获取有效组ID

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34397
跳转到指定楼层
楼主
发表于 2011-12-24 21:06:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
getgid()getegid() 的原型如下所示:
[C++] 纯文本查看 复制代码
#include <unistd.h>
#include <sys/types.h>

gid_t getgid(void);
gid_t getegid(void);

getuid() 用来获取执行当前进程的 GID 。
getedui() 用来获取执行当前进程的有效 GID 。

测试代码
[C++] 纯文本查看 复制代码
#include <errno.h>
#include <stdlib.h>

int main()
{
        printf ("Process's gid = %d, egid = %d\n", getgid(), getegid());

        int fd;

        if ( (fd = open("temp.txt", O_RDONLY)) == -1) {
                printf("Open failure, errno is %d:%s\n", errno, strerror(errno));
                exit (EXIT_FAILURE);
        } else {
                printf ("Open successfully!\n");
        }

        close(fd);

        exit (EXIT_SUCCESS);
}

在运行程序之前,先用 beyes 这个用户建立了一个 temp.txt 的文件:
ls -al temp.txt
-rw-r--r-- 1 beyes users 0 Dec 24 20:15 temp.txt
这里,该文件的属主是 beyes,用户组是 users 组,通过 /etc/passwd 文件可以看到,users 组的编号,即 gid 值为 100 。然后我们将该文件的其它组的读权限去掉:
chmod o-r temp.txt

接着在建立一个 groad 的用户,并用 usermod 命令将它的 gid 变为 101 ,如:
usermod -g 101 groad

下面分别用 beyes ,root,groad 这 3 个用户来运行该程序:
beyes
./getgid
Process's gid = 100, egid = 100
Open successfully!

root
# ./getgid
Process's gid = 0, egid = 0
Open successfully!

groad
./getgid
Process's gid = 101, egid = 101
Open failure, errno is 13:Permission denied

由上可见,groad 并没有权限打开该文件。

下面我们用 chmod 命令修改一下 getpid 这个程序的有效用户组权限:
chmod g+s getpid
也就是说,如果某个用户运行该程序,那么会继承 users 组的权限。此时再用 groad 这个用户运行该程序:
./getgid
Process's gid = 101, egid = 100
Open successfully!
由上可见,用户组的有效 GID 已经发生变化,变为 users 组,所以 groad 可以打开这个文件了。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-6-19 00:12 , Processed in 0.084650 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表