作为尝试在我的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
安静地通过脚本更改密码的正确方法是什么?
答案 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用户