winpexpect で plink を使用してリモート Linux サーバーに接続しようとしています。私は次のコードを使用しています:
child = winpexpect.winspawn('plink root@hostname')
child.logfile = sys.stdout
i = child.expect(['Password:')
child.expect('Password:')
child.sendline('password')
stdout で得られる出力は次のとおりです。
Using keyboard-interactive authentication.
Password: password
Using keyboard-interactive authentication.
Password:
Using keyboard-interactive authentication.
Password: Traceback (most recent call last):
File "<stdin>", line 1, in <module>
...in expect_loop
raise TIMEOUT (str(e) + '\n' + str(self))
pexpect.TIMEOUT: Timeout exceeded in read_nonblocking().
...
command: plink
args: ['plink', 'root@hostname']
buffer (last 100 chars): yboard-interactive authentication.
Password:
Using keyboard-interactive authentication.
Password:
before (last 100 chars): yboard-interactive authentication.
Password:
Using keyboard-interactive authentication.
Password:
after: <class 'pexpect.TIMEOUT'>
...
同等のコードが Linux の pexpect で機能する (winpexpect モジュールを pexpect に置き換え、plink 呼び出しを ssh に置き換える) ため、expect() の一致が正しいことがわかります。winpexpect が画面に書き込みを行っているように見えますが、plink はそれをパスワード フィールドに入力されたテキストとして登録していません。
誰でもここで問題を見つけることができますか?