我想知道用户是否是根用户,而不考虑该用户是否在使用类似fakeroot的工具。
我尝试了函数getuid()、geteuid()和getlogin(),但是当我启动fakeroot命令时,它们都发送自己的帐户信息,而不是root。
对于此代码:
printf("%d %d %s\n", getuid(), geteuid(), getlogin());我得到的是:
% fakeroot ./busybox rm
1000 1000 julien当我想得到这样的东西时:
0 0 root(登录就足够了)
发布于 2013-09-07 17:03:54
nneonneo的理由是正确的,但这里有一个解决方案:法克鲁特。它使用ptrace和系统调用拦截,而不是LD_PRELOAD和库调用拦截,这使得它与静态链接兼容,更加健壮,甚至能够处理从libc内部发出的调用(否则将无法连接)。
发布于 2013-09-07 16:59:05
看起来您的二进制文件(busybox)是针对静态libc编译的。fakeroot使用动态库预加载来拦截和替换对各种libc函数的调用,但是只有当二进制文件被动态链接到libc时,这才有效。如果它是静态链接的,则函数调用绑定到二进制文件中的实际调用,因此无法拦截它们。
https://stackoverflow.com/questions/18675686
复制相似问题