在一个脚本中悄悄地改变linux密码

作为试图在我的根ssh会话中实施安全措施的一部分,我试图devise一种在root用户loginn秒后启动脚本的方法,并更改用户密码并自动注销用户。

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

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

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

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

这没有多大帮助。

我试图pipestdout和stderr,但是我想我误解了pipe道。

 ~/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 

悄悄地通过脚本改变密码的正确方法是什么?

如果你想重定向stdout和sterr:

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

这相当于

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

这意味着“将stdout重定向到/ dev / null,然后将stderr重定向到stdout”。 这样你重定向stdout和stderr为空…但它可能是不够的(这将是在这种情况下,我相信)。 但理论上这个程序可能直接写入终端。 例如这个脚本

 $ 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将正常工作。

你也可以这样做:

 mkpasswd # Password:blah # BVR2Pnr3ro5B2 echo "user:BVR2Pnr3ro5B2" | chpasswd -e 

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

这对我有效

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

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