更新时间:2022-05-28 20:17:59
脚本目的:批量修改linux系统用户密码
条件:必须是修改的用户是root,因为只有root才有权限使用passwd命令
说明:先把IP、用户、密码、端口信息写到old_info文件中,脚本从这个文件读取对应的信息,利用expect免交互登陆系统。将随机生成的8位密码修改为root用户新密码。然后将新密码保存到net_info文件中。
1
2
3
4
5
|
# cat old_info # ip user passwd port #------------------------------------------------ 192.168.18.217 root 123456 22 192.168.18.218 root 123456 22 |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
# cat change_pass.sh #!/bin/bash OLD_INFO=~ /old_info
NEW_INFO=~ /new_info
for IP in ` awk '/^[^#]/{print $1}' $OLD_INFO`; do
USER=` awk - v I=$IP '{if(I==$1)print $2}' $OLD_INFO`
PASS=` awk - v I=$IP '{if(I==$1)print $3}' $OLD_INFO`
PORT=` awk - v I=$IP '{if(I==$1)print $4}' $OLD_INFO`
NEW_PASS=`mkpasswd -l 8`
echo "$IP $USER $NEW_PASS $PORT" >> $NEW_INFO
expect -c " spawn ssh -p$PORT $USER@$IP
set timeout 2
expect {
\"( yes /no )\" {send \" yes \r\";exp_continue}
\"password:\" {send \"$PASS\r\";exp_continue}
\"$USER@*\" {send \" echo \'$NEW_PASS\' | passwd --stdin $USER\r exit \r\";exp_continue}
#\"$USER@*\" {send \"df -h\r exit\r\";exp_continue}
}"
done |
1
2
3
|
# cat new_info 192.168.18.217 root n8wX3mU% 22 192.168.18.218 root c87;ZnnL 22 |