sshpass: 用于非交互的ssh 密码验证
??? $> sshpass -f user.passwd ssh user_name@192.168..1.2?#从环境变量获取密码? ? $> export SSHPASS="user_password"??? $> sshpass -e ssh user_name@192.168..1.2?----------------------------------------------------------------------------------------------------用sshpass实现ssh的自动登陆?
要实现ssh自动登录,网上搜了一下,主要有两种方法:1、生成公钥。2、编写expect脚本。这两种方法,用起来都有点复杂。在新立得上安装ssh的时候,偶然发现一个sshpass,百度谷歌之,英文资料甚多,而中文资料寥寥。其实sshpass的用法很简单。
用法:
??? sshpass 参数 SSH命令(ssh,sftp,scp等)。
??? 参数:
??? ??? -p password??? //将参数password作为密码。
??? ??? -f passwordfile //提取文件passwordfile的第一行作为密码。
??? ??? -e??? ??? //将环境变量SSHPASS作为密码。
??? 比如说:
??? ??? scp abc@192.168.0.5:/home/xxx/test /root?? 这个命令的作用是将服务器端文件test传到本地文件夹/root下。
??? ??? 利用sshpass,假设密码为efghi,则可写作:
??? ??? ssh -p efghi scp abc@192.168.0.5:/home/xxx/test /root
另外,对于ssh的第一次登陆,会提示:“Are you sure you want to continue connecting (yes/no)”,这时用sshpass会不好使,可以在ssh命令后面加上 -o StrictHostKeyChecking=no来解决。比如说上面的命令,就可以写作ssh -p efghi scp abc@192.168.0.5:/home/xxx/test /root -o StrictHostKeyChecking=no。
?
原文见:
http://blog.csdn.net/gsnumen/article/details/7293274
http://hi.baidu.com/liuhelishuang/item/aba87c36d55e81f52684f469