由于巡检过程中需要修改部分用户名密码,这些强密码包含大小写、数字和特殊符号,完全没有规律,让我手动输是不可能的,于是使用以下命令来输入,但是为了不在history里面留下痕迹,所以先关闭了历史命令功能:
bash
set +o history #关闭hittory
echo "new_password" | passwd --stdin username
注意这里有坑,如果密码里面有符号,那么会被认为是变量,我就遇到了这种情况,一直输密码不太对,所以前面要加上\进行转义。
比如:
bash
echo "new_password\$he" | passwd --stdin username
如果批量对用户修改密码,可以用以下方式:
bash
for i in {1..10};do
useradd username$i #用户名
password=`cat /dev/urandom|tr -dc '[:alnum:]'|head -c12` #使用生成的随机密码,12位
echo $password |passwd --stdin user$i &> /dev/null # 密码赋值
echo user$i:$password >> ~/user.log # 把用户名和密码都放到文件里面
echo "user$i is created"
done