端口转发和使用 Python Paramiko 的开放式 SFTP

Posted

技术标签:

【中文标题】端口转发和使用 Python Paramiko 的开放式 SFTP【英文标题】:Port forwarding and the open SFTP using Python Paramiko 【发布时间】:2020-11-13 08:14:46 【问题描述】:

我已经使用 ssh 在服务器上执行了命令。现在我必须在保持旧 ssh 处于活动状态的同时对不同的 IP 执行另一个 ssh。

这个新 IP 是端口转发,然后将用于执行 SFTP。

我面临的问题是两个 ssh 连接都在同一个端口上,因此无法进行第二个 ssh。 哪个 SFTP 失败。

任何对相同的支持都会有所帮助。

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(ip, username=username, password=password, port=22)
time.sleep(3)
#Invoke shell to open multiple channel with in one SSH
chan = ssh.invoke_shell()
chan.send(ip1+'\n')
time.sleep(5)
chan.send(pass1+'\n')
time.sleep(10)

chan.send("ssh "+ip2+'\n')

time.sleep(10)
chan.send(pass2+'\n')
time.sleep(5)
#Execute command
chan.send(cmd)

#connect to another ip to do sftp
ssh1 = paramiko.SSHClient()
ssh1.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect("127.0.0.4", username=usr2, password=pass2, port=22)
sftp=ssh.open_sftp()

【问题讨论】:

【参考方案1】:

看起来像是误会。您的代码不进行任何端口转发。

有关正确代码,请参阅Nested SSH using Python Paramiko。

如果您需要 SFTP,而不是 shell,只需:

jhost.open_sftp()

而不是

jhost.exec_command(command)

强制警告:不要使用AutoAddPolicy - 这样做会失去对MITM attacks 的保护。如需正确解决方案,请参阅Paramiko "Unknown Server"

【讨论】:

以上是关于端口转发和使用 Python Paramiko 的开放式 SFTP的主要内容,如果未能解决你的问题,请参考以下文章

python 使用paramiko模块上传本地文件到ssh

python paramiko的使用介绍

python中paramiko模块的使用

Python3_paramiko监控服务器端口(案例)

python之paramiko模块

python paramiko与linux的连接