用linux编写一个添加用户的脚本

用linux编写一个添加用户的脚本,第1张

cat "<a href="https://www.baidu.com/s?wd=tom&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1Y3uju-mHf1mHu9uhNbn1Rd0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EnHb3PH61rjbYPWc3nWDdPjfd" target="_blank" class="baidu-highlight">tom</a>:123" >/tmp/user.txt#生成密码文件,格式“username:password”

useradd <a href="https://www.baidu.com/s?wd=tom&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1Y3uju-mHf1mHu9uhNbn1Rd0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EnHb3PH61rjbYPWc3nWDdPjfd" target="_blank" class="baidu-highlight">tom</a> #增加用户,其它参数按需要添加

chpasswd /tmp/user.txt#设置用户密码

rm -f /tmp/user.txt#删除临时密码文件

首先要了解,添加一个用户不过是在passwd文件里面写入一行数据而已!所以呢,只要按照格式写就好了!

使用newuser和chpasswd工具即可批量添加用户以及创建密码!但要事先写好列表,使用newuser工具导入passwd文件中。格式要遵循passwd文件的格式!以及密码列表,格式为user:passwd,使用chpasswd将其写入passwd文件中,之后需要创建密文,用pwconv工具即可。如果之前你的passwd使用密文需要先将密文转换为明文,之后在进行密码列表导入。pwunconv

写好了,还在测试,测试好了就给你。

写好了,通过测试了。

########################################################################

#注:本脚本中使用了函数模块,以方便修改和调试

#************************************************

# 2011年12月10日 初稿

#************************************************

# 2011年12月11日 测试 问题:密码修改函数尚未实现

#************************************************

# 2011年12月11日 定稿 密码修改函数实现

#************************************************

#by bmw88661@126.com 12.11.2011

########################################################################

#设置变量

i=1

username=exam

password=gdlclinux

rmso=$(tput rmso)

smso=$(tput smso)

#此处可添加要求输入用户名和密码的项

#错误判断函数

SEA()

{

location=$( which useradd )#查找useradd的绝对路径

if [ \( "$location" = "" \) -o \( -s "$location" \) ] #判断是否找到useradd文件,或着找到的文件为空

then

echo "Useradd was not found,job terminated $smso unsuccessfully$rmso!"

exit

else

if [ -x "$location" ] #若useradd文件存在且不为空,判断是否具有可执行权限

then

echo "Command useradd doesn't have excution(x) mode"

exit

else#无法确定问题原因

echo "Script terminated by some unknown problem,Please check it!"

exit

fi

fi

}

#提示信息函数

casemsg()

{

#判断passwd执行的返回值,并进入case分支

case "$y" in

0) echo "Set password for $smso $username$i$rmso successfully"

1) echo "Permission denied when set password for $smso $username$i$rmso"

exit 1

2) echo "Invalid combination of options for command passwd"

exit 2

3) echo "Unexpected failure, nothing done"

exit 3

4) echo "Unexpected failure, passwd file missing"

exit 4

5) echo "Passwd file busy, try again"

exit 5

6) echo "Invalid argument to option"

exit 6

esac

}

#用户创建函数

usercreate()

{

useradd -m $username$i #如果需要其他功能,请参照useradd帮助手册修改此行,如:设置uid

x=$?

}

#密码修改函数

#这里如果你的系统里有chpasswd这个批修改工具的话,就不用这么麻烦了。

MOVpassword()

{

( echo "$password"sleep 1echo "$password" )|passwd $username$i#若useradd执行成功,则调用passwd设置密码

y=$?

}

#主循环

while [ "$i" -ge 1 -a "$i" -le 30 ]

do

usercreate #调用usercreate函数创建用户

if [ "$x" -eq 0 ] #判断useradd是否执行成功

then

echo "User $smso $username$i$rmso have been create successfully!"

MOVpassword #调用MOVpassword修改密码

casemsg #调用casemsg函数

if [ "$y" = 0 ] #如果MOVpassword的返回值为0,则将i加1

then

let i++

fi

else

SEA #调用错误判断函数

fi

done

unset i x y location rmso smso username password #释放所有设定的变量


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11739219.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存