shell应用之批量添加用户实例

这里要实现功能介绍
*读取一个用户列表文件
*给列表中的用户添加随机密码需要包含大小写字符和数字
*保存对应的用户和密码文件
*这些用户属于同个用户组

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----

posted @ 2018-11-07 13:35  小短腿跑得快  阅读(361)  评论(0编辑  收藏  举报