将 Paramiko 与 SOCKS 代理结合使用

问题描述 投票:0回答:2

我尝试将 Paramiko 与 SOCKS 代理一起使用(SecureCRT 或 PuTTY 配置为 SOCKS 代理)。我正在使用下面的代码

import paramiko,socks

host, port = '127.0.0.1', 1080

# Set up your proxy information for this socket
sock=socks.socksocket()
sock.set_proxy(
    proxy_type=socks.SOCKS4,
    addr=host,
    port=port,
)

# Connect the socket
sock.connect((host, port))

# Create your Paramiko Transport
transport = paramiko.Transport(sock)
transport.connect(
    username='username',     #<------not sure if it is needed, the socks proxy needs no username/password
    password='secret',
)
client = paramiko.client.SSHClient.connect('remotedevice', username='usernameonremotedevice',sock=sock)
stdin, stdout, stderr=client.exec_command("ls -la")
# Do stuff

# Clean up
client.close()
transport.close()

上述方法似乎让 Paramiko 感到困惑,因为它两者都使用 127.0.0.1。 我的问题起源于 Exscript 使用的 Paramiko 库,所以我想简化一下看看这是否有效......

这是 SecureCRT 每次尝试时显示的日志

[LOCAL] : Starting port forward from 127.0.0.1 on local 127.0.0.1:1080 to remote 127.0.0.1:1080.  
[LOCAL] : Could not start port forwarding from local service 127.0.0.1:3106 to 127.0.0.1:1080.  Reason: The channel could not be opened because the connection failed.  Server error details:     Connection refused  

脚本失败如下:

Traceback (most recent call last):
  File "C:\Users\Username\Documents\Eclipse\ESNetworkDiscovery\ParamikoProxyTest.py", line 24, in <module>
    sock.connect((host, port))
  File "C:\Utils\WPy2.7-32\python-2.7.13\lib\site-packages\socks.py", line 96, in wrapper
    return function(*args, **kwargs)
  File "C:\Utils\WPy2.7-32\python-2.7.13\lib\site-packages\socks.py", line 813, in connect
    negotiate(self, dest_addr, dest_port)
  File "C:\Utils\WPy2.7-32\python-2.7.13\lib\site-packages\socks.py", line 667, in _negotiate_SOCKS4
    raise SOCKS4Error("{0:#04x}: {1}".format(status, error))
socks.SOCKS4Error: 0x5b: Request rejected or failed
python ssh proxy paramiko socks
2个回答
9
投票

@pynexj 的答案是正确的,但有一个完整的工作示例总是好的:

import socks
import paramiko

sock=socks.socksocket()
sock.set_proxy(
    proxy_type=socks.SOCKS5,
    addr="proxy.host.name.example",
    port=1080,
    username="blubbs",
    password="blabbs"
)
sock.connect(('ssh.host.name.example', 22))

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('ignored without host key verification', username='caesar', sock=sock)
print((ssh.exec_command('ls')[1]).read().decode())
ssh.close()

(很高兴知道

sock
是否必须单独关闭……)

旁注:请确保不要将密码验证与

AutoAddPolicy
一起使用。最好根本不使用密码身份验证。 (见评论。)


3
投票

sock.connect((host, port))
应使用 SSH 服务器的主机名(与
SSHClient.connect()
使用的主机相同)和端口(默认
22
)。

© www.soinside.com 2019 - 2024. All rights reserved.