我正在构建一个ram文件系统,并且生成了一个“ /”目录.我想在生成的“ etc / shadow”文件上设置默认的root密码.
实际文件是:
root:*:15980:0:99999:7:::
bin:*:15980:0:99999:7:::
daemon:*:15980:0:99999:7:::
adm:*:15980:0:99999:7:::
...
.....
我想用“ root:Hashedpassword:”替换“ root:*:”,我知道用“ HASHEDPASSWORD”替换“ *”非常容易,但是应该使用模式“ root:anything:”来完成,这也不应该很困难,尽管我想在这里问一下,因为它可能对其他人有用.
例如:
我要设置的密码是“ centos”
盐是“ xyz”
我得到了散列的通行证:
pass=$(openssl passwd -1 -salt xyz centos)
然后,我想用“ sed”命令将“ root:anything:”中的“ anything”替换为“ root:Hashedpassword:”.
解决方法:
你可以用GNU sed来做到
sed -i -e "s/^root:[^:]\+:/root:$pass:/" etc/shadow
如果$pass中可能包含/字符,则可以使用其他分隔符,例如,如果该分隔符不存在.您可以这样做:
sed -i -e "s,^root:[^:]\+:,root:$pass:," etc/shadow
如果您没有GNU sed,则可能没有-i,或者可能需要一个参数.
您也可以使用awk执行此操作:
awk -F: "BEGIN {OFS=FS;} \$1 == \"root\" {\$2=\"$pass\"} 1" etc/shadow
如果您具有最新版本的GNU awk,则可以使用-i进行操作,如下所示:
awk -i inplace -F: "BEGIN {OFS=FS;} \$1 == \"root\" {\$2=\"$pass\"} 1" etc/shadow