作为试图在我的根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用户