0

我正在使用以下程序,并且我已经对其进行了 suid-ed(通过chown root XXX; chmod 4755 XXX以 root 身份运行),但输出仍然是ruid 1000, euid 1000, suid 1000,这里的 uid 不应该是零吗?

#define _GNU_SOURCE
#include <stdio.h>
#include <unistd.h>

int main()
{
        uid_t ruid, euid, suid;
        if (! getresuid (&ruid, &euid, &suid))
                printf ("ruid %d, euid %d, suid %d\n", ruid, euid, suid);
        else
                perror ("getresuid");

        return 0;
}

ls -l 的输出:

-rwsr-xr-x 1 root root 9.7K May 1 11:36 test*

4

1 回答 1

4

请检查mount命令输出,您的文件系统可以使用nosuid选项挂载。

从安装手册页

nosuid:不允许 set-user-identifier 或 set-group-identifier 位生效。

于 2013-05-01T04:00:46.267 回答