这里要实现功能介绍
*读取一个用户列表文件
*给列表中的用户添加随机密码需要包含大小写字符和数字
*保存对应的用户和密码文件
*这些用户属于同个用户组
1、列表文件
[root@mail ~]# cat listuser.txt
andy
tom
ailis
wate
job
eils
2、这里我们用mkpasswd 命令生成,没有这个命令安装以下
expect这个包
[root@mail ~]# mkpasswd -d 3 -l 13 -s 0 -C 2
Ppkvy0pOwg6m1
3、给用户设定密码或修改密码
第一种 echo -e "123123\n123123\n" | passwd root #>echo-e 是接收特殊符号,\n是换换行
第二种 echo -e "123123" |passwd --stdin root
脚本实例1
#!/bin/bash
if [ $# -eq 0 ] ;then
echo "input file path"
exit 1
fi
if [ ! -f $1 ] ;then
echo "input file name"
exit 1
fi
while read aa ;do
pd=`mkpasswd -l 12 -s 0`
useradd $aa
echo $pd |passwd --stdin $aa
echo "$aa \and\ $pd" >> user_passwd.txt
done < $1
[root@mail sbin]# sh mkku.sh /home/rrad/listuser.txt
更改用户 andy 的密码 。
passwd:所有的身份验证令牌已经成功更新。
更改用户 tom 的密码 。
passwd:所有的身份验证令牌已经成功更新。
更改用户 ailis 的密码 。
passwd:所有的身份验证令牌已经成功更新。
更改用户 wate 的密码 。
passwd:所有的身份验证令牌已经成功更新。
更改用户 job 的密码 。
passwd:所有的身份验证令牌已经成功更新。
更改用户 eils 的密码 。
passwd:所有的身份验证令牌已经成功更新。
[rrad@mail ~]$ cat listuser.txt
andy
tom
ailis
wate
job
eils
[rrad@mail ~]$
脚本实例2
[root@mail sbin]# cat user.sh
#!/bin/bash
if ! which mkpasswd &> /dev/null
then
echo "need mkpasswd"
yum install -y expect
fi
for i in `seq -w 1 10`
do
pd=`mkpasswd -l 12 -C 6 -d 3 -s 0`
echo "add_$i"
useradd add_$i
echo $pd |passwd --stdin add_$i
echo "add_$i : $pd" >> ./user_passwd
done
[root@mail sbin]# cat user_passwd
add_01 : PR5jBW1GdiH4
add_02 : uwM2LD4ZQF8l
add_03 : k1KTLuKc8G2Q
add_04 : B06lMOOikL7N
add_05 : 1ex68WCNKWJe
add_06 : HK8CWV0eA3sy
add_07 : MvE23Q9BUeiD
add_08 : 9vLY6FzLGgZ8
add_09 : TCuV13VZEs9l
add_10 : 6KUVPv5cB8yA
-----END----