添加个用户,再添加同名的用户组,并贴心的创建了家目录。连profile,bashrc这样的配置文件也一并复制过来了,家目录的权限也都属于用户。当场更改用户密码,允许设置登录shell。这供应象不像为某应用程序添加运行用户的场景?最后重申,必须以root账户运行。
#!/bin/bash
#dduser--Adds a new user to the system,including building their home
pwfile="/etc/passwd"
shadowfile="/etc/shadow"
gfile="/etc/group"
hdir="/home"
if [ "$(id -un)" != "root" ] ; then
? echo "Error: You must be root to run this command." >&2
? exit 1
fi
echo "Add new user account to $(hostname)"
echo -n "login: "???? ; read login
uid="$(awk -F: ‘{ if (big < $3 && $3 < 5000) big=$3 } END { print big + 1 }‘ $pwfile)"
homedir=$hdir/$login
# We are giving each user their own group,so gid=uid
gid=$uid #建立用户组
echo -n "full name: " ; read fullname
echo -n "shell: "???? ; read shell
echo "Setting up account $login for $fullname..."
echo ${login}:x:${uid}:${gid}:${fullname}:${homedir}:$shell >> $pwfile
echo ${login}:*:11647:0:99999:7::: >> $shadowfile
echo "${login}:x:${gid}:$login" >> $gfile
mkdir $homedir?? #建立家目录
cp -R /etc/skel/.[a-zA-Z]* $homedir? #将.bashrc,.profile之类的配置文件模板也一并复制到家目录里
chmod 755 $homedir
chown -R ${login}:${login} $homedir #更改家目录权限属于用户自己
# Setting an initial password
exec passwd $login
运行结果如下:
[[email?protected] opt]# ./adduser.sh Add new user account to localhost.localdomainlogin: lvfull name: lvdongbingshell: /bin/bashSetting up account lv for lvdongbing...更改用户 lv 的密码 。新的 密码:重新输入新的 密码:passwd:所有的身份验证令牌已经成功更新。