如何在BASH脚本中检查用户是否为root用户?
我知道我可以使用
[[ $UID -eq 0 ]] || echo "Not root"
或
[[ $EUID -eq 0 ]] || echo "Not root"
但是如果脚本是通过fakeroot调用的,UID和EUID都是0(当然,因为fakeroot伪造了root权限)。
但是有什么方法可以检查用户是否是root用户吗?不尝试做一些只有root用户才能做的事情(即在/中创建文件)?
Fakeroot设置自定义LD_LIBRARY_PATH
,其中包含指向libfakeroot
的路径。例如:
/usr/lib/x86_64-linux-gnu/libfakeroot:/usr/lib64/libfakeroot:/usr/lib32/libfakeroot
您可以使用它来检测应用程序是否在fakeroot内部运行,通过路径进行迭代并查找libfakeroot
。
样本代码:
IS_FAKEROOT=false
for path in ${LD_LIBRARY_PATH//:/ }; do
if [[ "$path" == *libfakeroot ]]; then
IS_FAKEROOT=true
break
fi
done
echo "$IS_FAKEROOT"
在这里,下面的脚本会发现用户是否是root用户。
#!/bin/bash
touch /checkroot 2>/dev/null
uid=`stat -c "%u" /checkroot 2>/dev/null`
if [ "$uid" = "0" ]
then
echo "Root user"
else
echo "Not a root user"
fi
rm /checkroot 2>/dev/null
在上面的例子中,我将尝试在根目录中创建一个文件,如果我不是根用户,并且我没有权限,它会给出错误,我将该错误重定向到/dev/null。
如果用户具有该权限,则会创建该文件。然后使用stat获取该文件的用户id,并将其存储到变量uid中。
在if条件中使用该变量,我将进行检查。
如果将创建临时文件,rm命令将删除该文件。
但请确保根目录中不存在该文件。