ssh自动连接(expect)

    技术2022-05-18  14

     

     

    昨天廖老师让尝试使用ssh脚本进行远程控制,但是这个东西需要手动去输入密码,不能放到后台去执行,于是就考虑有没有办法让他自动输入密码呢,经过查阅。最终发现了expect这个东西,很强大的东西,所以我就在本地测试了下,最终实现了不用手动输入密码也可以进行远程连接。不仅在ssh连接中可以用到,以后任何需要输入密码或者输入命令的,都可以,不仅保持了该软件的安全保密性又实现了智能性。拿来与大家分享.

     

            要使用expect需要预先安装tcl这个东西,然后再安装expect.我这里使用的是tcl8.4.13-src.tar.gzexpect-5.43.0.tar.gz的安装包.下载后,放在/home目录下:

     

    安装tclexpect

      

       #tar zxvf tcl8.4.3-src.tar.gz

       #cd tcl8.4.13

       #./configure && make && make install

       #cp tclUnixPort.h  ../generic/

      

       #tar zxvf expect-5.43.0.tar.gz

       #cd expect-5.43/

       #./configure --with-tcl=/usr/local/lib/ --with-tclinclude=/

         /home/tcl8.4.11/generic/  --with-x=no

       #make && make install

      

    介绍几个命令的含义:

    1. send

    用来发送一个字符串,比如 send "hello world"

    初始情况下,这个字符串会发送到标准输出。如果你用的是max OSX或者linux,可以在Terminal下直接输入expect命令并回车,就进入了expect交互环境,此时,输入send "hello world"就可以看到结果。

    一旦你的程序已经与其他程序进行交互,字符串就会被发送到其他程序那里。如上面的例子脚本中,我们调用send ”$password/r"就是把密码发送给SSH连接的服务器端指定端口。

     

    2. expect

    send相反,expect用来等待你所期望的字符串。比如expect "hello"expect后面跟的字符串中,你可以指定一个正则表达式。expect会一直等待下去,除非收到的字符串与预期的格式匹配,或者到了超期时间。

     

    3. spawn

    spawn用来启动一个新的进程,比如上面的spawn ssh -D $port $user@$hostExpect会执行命令“ssh -D $port $user@$host”

    在交互式的场景中,当你输入命令后,可能服务器端会返回一些操作提示符,以让你输入命令。Expect提供了这样三个常用的命令,spawn, expectsend,恰好满足这种需要。把它们结合起来使用,可以实现很多简单的自动化脚本。

    其它常用的命令还有:interact,比如你通过脚本自动连接到了某个ftp,并输入了用户名密码,此时需要人工输入一些命令,就可以使用interact命令,它会把脚本的控制权交给用户;sleep,等待多少秒等等。

         由于expect是从Tcl继承下来的,所以也支持Tcl的语法和命令,比如变量声明、流程控制等等。

     

     

     OK,tcl以及expect已经安装完成了.下面给出scp的一个expect很简单的一个脚本

     

    一个简单的小例子:

    #!/usr/local/bin/expect -f

     

    set user root

    set host 172.20.10.200

    set password 111111

    set timeout -1

     

    spawn ssh  $user@$host

        expect "*password:*"

    send "$password/r"

    expect eof

                


    最新回复(0)