我正在尝试使用useradd
. 我找到了一个我想尝试并合并的示例,尽管我无法理解特定部分。
这是整个示例:
if [ $(id -u) -eq 0 ]; then
read -p "Enter username : " username
read -s -p "Enter password : " password
egrep "^$username" /etc/passwd >/dev/null
if [ $? -eq 0 ]; then
echo "$username exists!"
exit 1
我了解基本情况,但具体而言:
[ $(id -u) -eq 0 ];
和
[ $? -eq 0 ];
我猜在括号内制作了一个变量。但我一直难以理解它们的目的或意义。
来自男人:
id -u
将打印用户的 ID。该脚本仅限于 UID 为 0 的 root 用户。$?
先前执行的命令的退出状态。该
id
实用程序与它的-u
选项一起使用时,将输出当前用户的 UID。如果该 UID 为零,则该用户是 root 用户。只有 root 用户才能添加新用户。因此,脚本再次测试运行脚本的用户的 UID 为零,并且如果用户是 root,则仅执行特权操作(问题的脚本中未显示)。
如果整个脚本需要 root,则在脚本中处理此问题的一种可以说是更好的方法是检查 UID 在开始时是否非零,如果是,则以错误退出:
至于
$?
,它是一个特殊的 shell 变量,总是包含最近执行的命令的退出状态。很少需要直接使用它,因为它if
不仅能够直接使用grep
:在这里,
if
将使用 的退出状态grep
。我们使用grep
with-q
来阻止它产生任何输出,并阻止它解析任何第一个匹配后的整个文件。它只是返回if
将使用的退出状态。我们也不需要egrep
,因为正则表达式不是扩展正则表达式(egrep
与 相同grep -E
)。另请注意,诊断消息应写入标准错误流。您可以通过使用 重定向您的消息来做到这一点
>&2
。此外,在输出可变数据时printf
更可取echo
。如果您在使用 NIS 或 LDAP 等目录服务的系统上,则对现有用户进行 grepping
/etc/passwd
可能没有用,因为实际用户很可能存储在单独的数据库中。在这样的系统上,使用它可能会更好
getent passwd "$username"
(这也适用于非 NIS/LDAP 系统)。这将返回特定用户的密码数据库条目,或者以非零退出状态退出,这意味着我们可以在测试中使用它:请注意,
useradd
不能将用户添加到 NIS 或 LDAP 数据库...useradd
虽然,严格来说,如果当前用户不是 root 或者如果被添加的用户已经存在,那么上面的任何内容都不应该真正需要,因为不应该做任何有用的事情。