zoukankan      html  css  js  c++  java
  • expect脚本解释

    1. 使用expect实现自动登录的脚本,网上有很多,可是都没有一个明白的说明,初学者一般都是照抄、收藏。可是为什么要这么写却不知其然。本文用一个最短的例子说明脚本的原理。  
    2.   
    3.   
    4.   
    5. 脚本代码如下:  
    6.   
    7. ##############################################  
    8.   
    9. #!/usr/bin/expect  
    10.   
    11. set timeout 30  
    12.   
    13. spawn ssh -l username 192.168.1.1  
    14.   
    15. expect "password:"  
    16.   
    17. send "ispass\r"  
    18.   
    19. interact  
    20.   
    21. ##############################################  
    22.   
    23.   
    24.   
    25. 1. [#!/usr/bin/expect]  
    26.   
    27. 这一行告诉操作系统脚本里的代码使用那一个shell来执行。这里的expect其实和linux下的bash、windows下的cmd是一类东西。  
    28.   
    29.   
    30.   
    31. 注意:这一行需要在脚本的第一行。  
    32.   
    33.   
    34.   
    35. 2. [set timeout 30]  
    36.   
    37. 基本上认识英文的都知道这是设置超时时间的,现在你只要记住他的计时单位是:秒  
    38.   
    39.   
    40.   
    41. 3. [spawn ssh -l username 192.168.1.1]  
    42.   
    43. spawn是进入expect环境后才可以执行的expect内部命令,如果没有装expect或者直接在默认的SHELL下执行是找不到spawn命令的。所以不要用 “which spawn“之类的命令去找spawn命令。好比windows里的dir就是一个内部命令,这个命令由shell自带,你无法找到一个dir.com 或 dir.exe 的可执行文件。  
    44.   
    45. 它主要的功能是给ssh运行进程加个壳,用来传递交互指令。  
    46.   
    47.   
    48.   
    49. 4. [expect "password:"]  
    50.   
    51. 这里的expect也是expect的一个内部命令,有点晕吧,expect的shell命令和内部命令是一样的,但不是一个功能,习惯就好了。这个命令的意思是判断上次输出结果里是否包含“password:”的字符串,如果有则立即返回,否则就等待一段时间后返回,这里等待时长就是前面设置的30秒  
    52.   
    53.   
    54.   
    55. 5. [send "ispass\r"]  
    56.   
    57. 这里就是执行交互动作,与手工输入密码的动作等效。  
    58.   
    59.   
    60.   
    61. 温馨提示: 命令字符串结尾别忘记加上 “\r”,如果出现异常等待的状态可以核查一下。  
    62.   
    63.   
    64.   
    65. 6. [interact]  
    66.   
    67. 执行完成后保持交互状态,把控制权交给控制台,这个时候就可以手工操作了。如果没有这一句登录完成后会退出,而不是留在远程终端上。如果你只是登录过去执行一段命令就退出,可改为[expect eof]  
  • 相关阅读:
    高效存储过程分页
    c#函数参数
    MonoRail学习:可重复组件ViewComponents的使用
    跨域SSO的实现
    WebSockets基础
    NVelocity用法
    MonoRail MVC应用(2)-构建多层结构的应用程序
    MonoRail学习-入门实例篇
    关于transform属性导致字体模糊的问题
    在小程序中实现收缩展开
  • 原文地址:https://www.cnblogs.com/iloveyoucc/p/2561179.html
Copyright © 2011-2022 走看看