问题描述
我正在尝试使用子进程生成一个 ssh 子进程.
I'm trying to spawn an ssh child process using subprocess.
我正在 Windows 7 上开发 Python 2.7.6
I'm working on Python 2.7.6 on Windows 7
这是我的代码:
from subprocess import *
r=Popen("ssh sshserver@localhost", stdout=PIPE)
stdout, stderr=r.communicate()
print(stdout)
print(stderr)
输出:
None
stdout 应包含:sshserver@localhost 的密码:
stdout should contain: sshserver@localhost's password:
推荐答案
这是一个工作 SSH 代码的示例,它处理证书部分是/否的提示以及在要求输入密码时.
Here's an example of working SSH code that handles the promt for yes/no on the certificate part and also when asked for a password.
#!/usr/bin/python
import pty, sys
from subprocess import Popen, PIPE, STDOUT
from time import sleep
from os import fork, waitpid, execv, read, write
class ssh():
def __init__(self, host, execute='echo "done" > /root/testing.txt', askpass=False, user='root', password=b'SuperSecurePassword'):
self.exec = execute
self.host = host
self.user = user
self.password = password
self.askpass = askpass
self.run()
def run(self):
command = [
'/usr/bin/ssh',
self.user+'@'+self.host,
'-o', 'NumberOfPasswordPrompts=1',
self.exec,
]
# PID = 0 for child, and the PID of the child for the parent
pid, child_fd = pty.fork()
if not pid: # Child process
# Replace child process with our SSH process
execv(command[0], command)
## if we havn't setup pub-key authentication
## we can loop for a password promt and "insert" the password.
while self.askpass:
try:
output = read(child_fd, 1024).strip()
except:
break
lower = output.lower()
# Write the password
if b'password:' in lower:
write(child_fd, self.password + b'
')
break
elif b'are you sure you want to continue connecting' in lower:
# Adding key to known_hosts
write(child_fd, b'yes
')
elif b'company privacy warning' in lower:
pass # This is an understood message
else:
print('Error:',output)
waitpid(pid, 0)
您无法立即读取 stdin 的原因(如果我在这里错了,请纠正我)是因为 SSH 在您需要的不同进程 ID 下作为子进程运行阅读/附加到.
The reason (and correct me if i'm wrong here) for you not being able to read the stdin straight away is because SSH runs as a subprocess under a different process ID which you need to read/attach to.
由于您使用的是 windows,所以 pty 将不起作用.有两种解决方案会更好,那就是 pexpect 和有人指出的基于密钥的身份验证.
Since you're using windows, pty will not work. there's two solutions that would work better and that's pexpect and as someone pointed out key-based authentication.
为了实现基于密钥的身份验证,您只需执行以下操作:在您的客户端上,运行:ssh-keygen将您的 id_rsa.pub 内容(一行)复制到服务器上的 /home/user/.ssh/authorized_keys 中.
In order to achieve a key-based authentication you only need to do the following:
On your client, run: ssh-keygen
Copy your id_rsa.pub content (one line) into /home/user/.ssh/authorized_keys on the server.
你就完成了.如果没有,请使用 pexpect.
And you're done. If not, go with pexpect.
import pexpect
child = pexpect.spawn('ssh user@host.com')
child.expect('Password:')
child.sendline('SuperSecretPassword')
这篇关于如何使用子进程模块与 ssh 交互的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!


大气响应式网络建站服务公司织梦模板
高端大气html5设计公司网站源码
织梦dede网页模板下载素材销售下载站平台(带会员中心带筛选)
财税代理公司注册代理记账网站织梦模板(带手机端)
成人高考自考在职研究生教育机构网站源码(带手机端)
高端HTML5响应式企业集团通用类网站织梦模板(自适应手机端)