Pexpect没有在Yes / No提示下工作

时间:2018-04-20 11:56:04

标签: python pexpect

我正在使用pexpect登录并在cisco路由器上运行命令。它在RSA是/否提示时陷入困境而不是发送“是”。以下是代码片段:

fout = file(filepath,'w')
child = pexpect.spawn('ssh %s@%s' % (username, agg))
child.logfile_read = fout
rsa_key = '\(yes\/no\)\?' 
prompt = "Password:"
i = child.expect([rsa_key,prompt,""])
if i==0:
    child.sendline('yes')
    child.expect(prompt)
    child.sendline(password)
elif i==1:
    child.sendline(password)
else:       
    child.sendline(password)

child.expect('>')
child.sendline('enable')
child.expect('Password:')
child.sendline(password)
child.expect('#')
child.sendline('terminal length 0')
child.expect('#')
child.sendline('show processes cpu history')
child.expect('#')
child.sendline('logout')

这是我得到的错误:

Traceback (most recent call last):
  File "/usr/pre_check.py", line 378, in <module>
    agg_check = agg_checks(agg,username,password)
  File "/usr/pre_check.py", line 198, in agg_checks
    child.expect('>')
  File "/usr/local/lib/python2.7/dist-packages/pexpect/spawnbase.py", line 327, in expect
    timeout, searchwindowsize, async_)
  File "/usr/local/lib/python2.7/dist-packages/pexpect/spawnbase.py", line 355, in expect_list
    return exp.expect_loop(timeout)
  File "/usr/local/lib/python2.7/dist-packages/pexpect/expect.py", line 104, in expect_loop
    return self.timeout(e)
  File "/usr/local/lib/python2.7/dist-packages/pexpect/expect.py", line 68, in timeout
    raise TIMEOUT(msg)
pexpect.exceptions.TIMEOUT: Timeout exceeded.
<pexpect.pty_spawn.spawn object at 0x7f6c5e4b89d0>
command: /usr/bin/ssh
args: ['/usr/bin/ssh', 'username@router']
buffer (last 100 chars): 'TyefPiveH4nHv1dfvbL/MFbqSR+dup1U7Cn+JaDeq0.\r\nAre you sure you want to continue connecting (yes/no)? '
before (last 100 chars): 'TyefPiveH4nHv1dfvbL/MFbqSR+dup1U7Cn+JaDeq0.\r\nAre you sure you want to continue connecting (yes/no)? '
after: <class 'pexpect.exceptions.TIMEOUT'>
match: None
match_index: None
exitstatus: None
flag_eof: False
pid: 28991
child_fd: 7
closed: False
timeout: 30
delimiter: <class 'pexpect.exceptions.EOF'>
logfile: None
logfile_read: <open file 'mylogfile.txt', mode 'w' at 0x7f6c5e53ee40>
logfile_send: None
maxread: 2000
ignorecase: False
searchwindowsize: None
delaybeforesend: 0.05
delayafterclose: 0.1
delayafterterminate: 0.1
searcher: searcher_re:
    0: re.compile(">")

我已尝试使用相同问题的rsa_key变量的varius版本:

  • 您确定要继续连接(是/否)\?
  • 您确定要继续连接(是/否)?
  • 您确定要继续连接吗
  • (是/否)?
  • (是/否)\?
  • (是/否)

这是ssh到开关时的样子:

ssh username@routername
The authenticity of host 'routername (11.111.111.1)' can't be established.
RSA key fingerprint is SHA256:KCS1HKzltOwHgg+WhTsV3OTxNzxUQwN9T3Jp1lGVu00.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'routername,11.111.111.1' (RSA) to the list of known hosts.
Password: 

routername>

2 个答案:

答案 0 :(得分:0)

就我个人而言,我会用ssh -o StrictHostKeyChecking=no躲闪那一点,因为看起来你不在乎根据任何解释作出决定。我不确定您传递给期望调用的列表中的空字符串匹配的用例,但似乎无论索引如何,您都在发送密码并期望提示,就好像初始身份验证和hostchecking已完成一样。您收到的错误显示缓冲区包含yes / no提示符,但期望在>期间失败。您的密码可能会被发送到是没有提示,然后显示“请输入'是'或'否':”不包含>导致您超时。

答案 1 :(得分:0)

您需要使用“(?i)是/否”。我遇到了同样的问题。