最近几天由于工作需要,要在suse操作系统下实现一个验证root密码正确性的shell脚本,没想到什么好办法,最后用一个取巧的方式应付了,方法如下:
1、通过su - root命令尝试切换到root用户;
2、假设密码是正确的,那么切换成功后,通过whoami命令打印一下切换后的当前用户;
3、判断输出结果是否是root,来间接证明root密码是否正确。
具体脚本如下:
#!/bin/bash
root_pwd=$1
#获取当前脚本目录
cmddir=`dirname $0`
cmddir=`cd ${cmddir}/;pwd`
#定义一个临时脚本,该脚本用于输出切换用户后的当前用户
temp_script="${cmddir}/temp.sh"
#生成temp_script脚本及其内容
echo '#!/bin/bash' >${temp_script}
echo 'pwd' >>${temp_script}
#定义切换用户函数
get_user()
{
su - root<<EOF
${root_pwd}
bash ${temp_script}
EOF
}
#执行切换函数,并获取输出结果
user=`get_user`
#判断是否root用户
if [ "${user}" == "root" ]
then
echo "correct root password"
else
echo "invalid root password"
fi
注意事项:
1、该脚本应在非root用户下执行
2、get_user函数中的那几行代码要顶格写(这应该是here document 的要求,否则报错)
3、实际编写脚本的时候最好不用写中文,哪怕是注释
起初有想过用expect脚本来实现,但是关键字匹配比较麻烦,因为不同语言的操作系统,其关键字不一样最后还是用了上面的方式。