sshpass: 用于非交互的ssh 密码验证
Posted PHPdragon
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sshpass: 用于非交互的ssh 密码验证相关的知识,希望对你有一定的参考价值。
ssh登陆不能在命令行中指定密码,也不能以shell中随处可见的,sshpass 的出现,解决了这一问题。它允许你用 -p 参数指定明文密码,然后直接登录远程服务器。 它支持密码从命令行,文件,环境变量中读取
$> sshpass -h Usage: sshpass [-f|-d|-p|-e] [-hV] command parameters -f filename Take password to use from file -d number Use number as file descriptor for getting password -p password Provide password as argument (security unwise) -e Password is passed as env-var "SSHPASS" With no parameters - password will be taken from stdin -h Show help (this screen) -V Print version information At most one of -f, -d, -p or -e should be used
sshpass [-f|-d|-p|-e] [-hV] command parameters 中的 command parameters 和使用交互式密码验证的使用方法相同
#从命令行方式传递密码
$> sshpass -p user_password ssh [email protected]192.168..1.2 $> sshpass -p user_password scp -P22 192.168.1.2:/home/test/t .
#从文件读取密码
$> echo "user_password" > user.passwd $> sshpass -f user.passwd ssh [email protected]192.168..1.2
#从环境变量获取密码
$> export SSHPASS="user_password" $> sshpass -e ssh [email protected]192.168..1.2
对于ssh的第一次登陆,会提示:
“Are you sure you want to continue connecting (yes/no)”,这时用sshpass会不好使,可以在ssh命令后面 -o StrictHostKeyChecking=no
来解决。比如说上面的命令,就可以写作
ssh [email protected] -o StrictHostKeyChecking=no
“Are you sure you want to continue connecting (yes/no)”,这时用sshpass会不好使,可以在ssh命令后面 -o StrictHostKeyChecking=no
来解决。比如说上面的命令,就可以写作
ssh [email protected] -o StrictHostKeyChecking=no
PS:
源码位置:http://sourceforge.net/projects/sshpass/
以上是关于sshpass: 用于非交互的ssh 密码验证的主要内容,如果未能解决你的问题,请参考以下文章