脚本目的:批量修改linux系统用户密码

条件:必须是修改的用户是root,因为只有root才有权限使用passwd命令

说明:先把IP、用户、密码、端口信息写到old_info文件中,脚本从这个文件读取对应的信息,利用expect免交互登陆系统。将随机生成的8位密码修改为root用户新密码。然后将新密码保存到net_info文件中。

 

# cat old_info

#     ip     user   passwd    port

#------------------------------------------------

192.168.18.217  root    n8wX3mU%    22

192.168.18.218  root    c87;ZnnL    22

 

# 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\rexit\r\";exp_continue}

       #\"$USER@*\"  {send\"df -h\r exit\r\";exp_continue}

    }"

done

 

# cat new_info

192.168.18.217  root    n8wX3mU%        22

192.168.18.218  root    c87;ZnnL        22