这里分两种情况,一种是测试for循环批量添加用户,一个是根据实际生产环境进行批量添加。分别写一下案例如下:
for添加指定类型用户以及设置随机密码
脚本作用:批量添加user1-10用户并设置随机8位数随机密码
#!/bin/bash
#test add user and set passwd
for n in `seq 10`
do
useradd user$n;
echo user$n |passwd `echo user$n |md5sum |cut -c1-8`
done
实际生产环境批量添加用户和设置对应密码
脚本作用:在生产环境中批量添加指定用户、设置对应密码,并禁止sudo -s、sudo -i切换到root。
思路:将所有要添加的用户名和密码放到一个数组中,设置一个函数进行截取用户名和密码并进行添加用户、设置密码。最后用一个循环调用这个函数即可添加。
#!/bin/bash
#adduser and set passwd
userlist=(
user21:123456
user22:456789
user23:876543
)
function adduser_setpasswd_sudo(){
user=`echo $1 |awk -F: '{print $1}'`
passwd=`echo $1 |awk -F: '{print $2}'`
useradd -m -s /bin/bash $user
echo "$user:$passwd"|chpasswd
sed -i "/${user}/d" /etc/sudoers
echo "${user} ALL=NOPASSWD:ALL,!/usr/bin/passwd,/usr/bin/passwd [a-zA-Z]*,!/usr/bin/passwd root,!/bin/bash" >> /etc/sudoers
}
for n in ${userlist[@]}
do
adduser_setpasswd_sudo $n
done
删除要取消的账户以及取消sudo权限
#!/bin/bash
cat < < EOF
##############################################################
delete username and cancle sudo privileges.
##############################################################
EOF
read -p "Please input username which you want to del:" username
userdel -r $username
sed -i "/${username}/d" /etc/sudoers
echo "Delete $username finished."