悄悄地在脚本中更改linux密码

时间:2013-02-22 11:43:20

标签: linux bash shell unix passwd

作为尝试在我的root ssh会话中实现安全措施的一部分,我正在尝试设计一种在root用户登录n秒后启动脚本的方法,并更改用户密码并自动注销用户。 / p>

我在试图默默地更改密码时遇到困难。我有以下代码:

echo -e "new\nnew" | passwd -q

这不是像手册页中提到的那样“静静地”更改密码,而是输出:

~/php-pastebin-v3 #echo -e "new\nnew" | passwd -q
Enter new UNIX password: Retype new UNIX password: passwd: password updated successfully

没有多大帮助。

我试图管道stdout和stderr,但是我觉得我误解了管道。

~/php-pastebin-v3 #echo -e "new\nnew" | passwd -q > /dev/null
Enter new UNIX password: Retype new UNIX password: passwd: password updated successfully

~/php-pastebin-v3 #echo -e "new\nnew" | passwd -q /dev/null 2>&1
passwd: user '/dev/null' does not exist

安静地通过脚本更改密码的正确方法是什么?

3 个答案:

答案 0 :(得分:4)

如果你想重定向stdout和sterr:

echo "..." | passwd &> /dev/null

相当于

echo "..." | passwd > /dev/null 2>&1

表示“将stdout重定向到/ dev / null,然后将stderr重定向(复制)到stdout”。这样你将stdout和stderr重定向到null ......但它可能还不够(在这种情况下我会相信)。但理论上,程序可能直接写入终端。例如这个脚本

$ cat test.sh
echo stdout
echo stderr 1 1>&2
echo stderr 2 >/dev/stderr
echo stderr 3 >/dev/fd/2
echo bad luck > /dev/tty

$ ./test.sh &> /dev/null
bad luck

要消除此输出,您必须强制程序在伪终端中运行,例如http://empty.sourceforge.net/。但这只是一个旁注&> / dev / null将正常工作。

答案 1 :(得分:3)

您也可以这样做:

mkpasswd
# Password:blah
# BVR2Pnr3ro5B2

echo "user:BVR2Pnr3ro5B2" | chpasswd -e

所以密码已在脚本中加密。

答案 2 :(得分:0)

这对我有用

echo "passssssword" | passwd root --stdin > /dev/null

注意: --stdin仅适用于root用户