我需要能够在我的Linux (Fedora 10)上创建用户帐户,并通过bash脚本自动分配密码(如果需要,也可以采用其他方式)。

通过Bash创建用户很容易,例如:

[whoever@server ]#  /usr/sbin/useradd newuser

是否可以在Bash中分配密码,功能类似于此,但自动:

[whoever@server ]# passwd newuser
Changing password for user testpass.
New UNIX password:
Retype new UNIX password: 
passwd: all authentication tokens updated successfully.
[whoever@server ]#

当前回答

——stdin在Debian上不起作用。它说:

`passwd: unrecognized option '--stdin'`

这招对我很管用:

#useradd $USER
#echo "$USER:$SENHA" | chpasswd

在这里我们可以找到一些其他的好方法:

http://www.debian-administration.org/articles/668

其他回答

我喜欢Tralemonkey的方法echo thePassword | passwd theUsername—stdin,虽然它不太适合我写的。然而,这对我来说很有效。

echo -e "$password\n$password\n" | sudo passwd $user

-e是将\n识别为新行。

sudo是Ubuntu的根权限。

双引号用于识别$并展开变量。

上面的命令两次将密码和新行传递给passwd,这是passwd所需要的。

如果不使用变量,我认为这可能可行。

echo -e 'password\npassword\n' | sudo passwd username

单引号在这里就足够了。

我知道我要过几年才会有这个想法,但我不敢相信居然没有人建议用户mod。

usermod --password `perl -e "print crypt('password','sa');"` root

如果有人想在旧的HPUX上执行此操作,您可以使用usermod.sam。

/usr/sam/lbin/usermod.sam -F -p `perl -e "print crypt('password','sa');"` username

只有当执行脚本的人是当前用户时才需要使用-F。当然,您不需要使用Perl来创建散列。您可以使用openssl或许多其他命令来代替它。

./my_add_user.sh用户PASSWD

代码:

#!/bin/bash
# my_add_user.sh

if [ "$#" -lt 2 ] 
 then
       echo "$0 username passwd"
       exit
fi

user=$1
passwd=$2

useradd $user -d /data/home/$user  -m  ;
echo $passwd | passwd $user --stdin;

您可以运行passwd命令并向其发送管道输入。所以,你可以这样做:

echo thePassword | passwd theUsername --stdin

单行程序创建一个带有主目录和密码的sudo用户。

useradd -m -p $(openssl passwd -1 ${PASSWORD}) -s /bin/bash -G sudo ${USERNAME}