要实现ssh自动登录,
主要有三种方法:
1、生成公私钥。
2、编写expect脚本。
3、用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会不好使,解决方法:
1.可以在ssh命令后面加上 -o StrictHostKeyChecking=no来解决。比如说上面的命令,就可以写作ssh -p efghi scp abc@192.168.0.5:/home/xxx/test /root -o StrictHostKeyChecking=no。
2.或者写入配置文件:把 StrictHostKeyChecking no 加到/etc/ssh/ssh
config 可以让ssh客户端自动接受新主机的hostkey,不用每次都自己输入yes
交叉编译arm版本,
在sshpass目录执行:
./configure
./make CC=arm-linux-gcc
自动传文件:
./sshpass -p 111111 ./scp -S ./ssh -o StrictHostKeyChecking=no -r ./test.file
testuser@192.168.0.10:./
sshpass依赖pts,若pst没有加载,则执行 Bash代码
|
实现ssh自动登陆的三种方式
最新推荐文章于 2025-02-20 15:28:08 发布