useradd -p后面跟的passwd必须是经过crypt加密过的密码,
因为用户登录时,系统会将密码加密后再和/etc/shadow中相应用户的密码字段匹配。
解决办法:
以root用户创建测试用户,密码设置为你想要的密码(这里假设密码为“Oracle”):
useradd test
passwd test
设置test用户的密码为: oracle
获取密码密文:
cat /etc/shadow | grep test
test:$1$uRUnO/uA$H7aPFUcugcizXCASaEADy.:14606:0:99999:7:::
头两个冒号之间的内容即为明文密码oracle对应的密文:
oracle ==> $1$uRUnO/uA$H7aPFUcugcizXCASaEADy.
使用-p参数带密码创建用户
useradd -p \$1\$uRUnO/uA\$H7aPFUcugcizXCASaEADy. Test2
注意: 要对$等特殊字符使用转义字符(在其前面添加一个反斜杠:\)
测试
现在使用 oracel/oracle进行登录测试
MarkEd by knityster.