让Linux的SSH客户端也能记住服务器的密码

一位网友的问题如下:

以前一直用windows,最近工作原因换Ubuntu了,但是windows下的SSH客户端(我用的是Netsarang公司的 Xshell,Xftp,Xmanager),linux没有相应版本,尝试了下putty,觉得很不好用,最重要的是要保存10多个服务器的密码。说明一下,密码是系统产生的随机长串,无法记忆的,公司的运维统一管理的,所以别跟我说什么更换成key文件之类的,我就要找个Linux下可以保存密码的 SSH客户端,命令行还是图形化界面都无所谓,谢谢大家!

我第一次看到问题时还在纳闷,Linux自带ssh命令,还需要ssh客户端干什?后来一看,这位朋友是想记住服务器的密码。

懒人!!

懒人有懒人的福,解决方案还是有的。

我的解决方案如下:

1. 先安装sshpass

下载:wget

安装:

tar -zxvf sshpass-1.04.tar.gz

cd sshpass-1.04

./configure

make && make install

2. 再写一个管理sshpass的BASH脚本.

脚本文件名为:/opt/program/bash/test.sh

脚本内容如下:

#!/bin/bash

cat <<MENU

1) localhost

2) 192.168.100.100

3) 加上你的主机

MENU

echo -n "Your choose:"

read host

case "$host" in

1)

exec /usr/local/bin/sshpass -p 123456(这是我机器的密码) ssh huabo@localhost

;;

2)

exec /usr/local/bin/sshpass -p 123456 ssh huabo@192.168.100.100

;;

3)

你的登录命令

;;

*)

echo "Error, No host"

;;

esac

3.测试一下

[root@server bash]# ./test.sh

1) localhost

2) 192.168.100.100

Your choose:2

Last login: Mon Jun 29 02:34:49 2009 from 192.168.100.100

[huabo@server ~]$ ls

opera.exe  zabbix-1.6.4  zabbix-1.6.4.tar.gz

[huabo@server ~]$

测试成功!你只需把密码写到脚本里面,执行此脚本,选择相应的主机就行了.

此脚本还可优化一下,搞成:test.sh localhost这种形式更方便。

此外还要注意一点,你需要先手动登录一次,因为第一次登录时会提示:

Are you sure you want to continue connecting (yes/no)?

(脚本没考虑这点)

PS:你自己把密码存脚本里的哈,出了问题不要怪我.

(先前的expect脚本不对,这是第二版,放心用吧。点击这里下载

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wyzsyd.html