如果没有在useradd时候指定的话,是没有密码的。第一次用该用户登陆系统的时候,系统会提示你修改密码。

只能用passwd修改密码

useradd -p 设密码

useradd有一个选项 p,可以直接设置密码,但是是密文,形如$1$EaTjv12a$yAYHKjRflqHtqH807o59D0

这是加密过的,比如我想给用户设置的密码为123456,那么你在现在系统中设置一个用户密码用passwd,在/etc/shadow的第二个字段,拿到这个密文就可以用p直接设置密码了

useradd -p\$1\$EaTjv12a\$yAYHKjRflqHtqH807o59D0 user

useradd命令 -p 参数的一个误解

关键词: useradd

linux下 man useradd可以看到帮助,其中-p参数的解释如下:

-p passwd

The encrypted password, as returned by crypt(3). The default is

to disable the account.

英语好的人也许一看就懂了,但是我不是,我很弱。所以也因此疑惑了一天。

我本来打算用useradd命令添加用户后就可以直接赋予密码的,故此我在root下添加用户

/usr/sbin/useradd -d '/home' -p iampig123 hehe

尝试了下,不能用该密码登陆

/usr/sbin/useradd -d '/home' -p 'iampig123' hehe

还是不行。

这是为什么呢,在高手的指点下我才看懂了,原来帮助里面说得很清楚了,

as returned by crypt(3),也就是说这里写得必须是加密得字符。

linux将帐号信息保存在/etc/passwd,将密码信息保存在/etc/shadow,

因使用加密策略,保存在shadow中的是隐性的代号。

说我们cat一下就可以看到许多账号的信息

比方说如下这行

deepspace:$1$zpe.sRXJ$Id6zoW0h.9xn6b84Ybfjo/:13200:0:99999:7:::

也就是说如果你非要用-p参数来直接赋予密码的话,必须使用那窜加密过的字符串;)

编辑/etc/passwd文件。

[组名]:[口令]:[组ID]:[用户]。

如果使用了shadow隐藏口令,就编辑/etc/shadow文件

要有root权限。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐