我有下面的代码片段。
char *const parmList[] = {"sh", "-c", "whoami", NULL};
if(geteuid() == 0) {
seteuid(atoi(getenv("SUDO_UID")));
}
posix_spawn(&pid, "/bin/sh", NULL, NULL, parmList, environ);根据我的理解,posix_spawn的默认行为是:
如果没有设置
POSIX_SPAWN_RESETIDS标志,子进程将继承父进程的有效用户ID。
然而,当我使用sudo运行我的程序时,我仍然得到root作为来自posix_spawn的输出。如何使posix_spawn作为原始用户运行?有更好的方法吗?
发布于 2016-11-10 17:51:09
最后,我创建了一个fork的函数,然后创建了exec的函数,从而完成了这个任务。
pid_t runCmd(char *cmd) {
if(!cmd) return -1;
pid_t ans = fork();
if(ans == 0) {
if(geteuid() == 0) {
int uid = atoi(getenv("SUDO_UID"));
setreuid(uid, uid);
}
if(verbose_flag) println("uid %d; euid %d", getuid(), geteuid());
char *const parmList[] = {"sh", "-c", cmd, NULL};
execv("/bin/sh", parmList);
}
return ans;
}whoami现在返回原始用户
https://stackoverflow.com/questions/40532401
复制相似问题