使用python中的paramiko库使用SOCKS进行动态应用程序级端口转发

时间:2013-05-21 13:46:53

标签: python ssh putty paramiko socks

我正在尝试以下列方式连接到SSH服务器:

import paramiko
import socks
sock = socks.socksocket()
sock.setproxy(socks.PROXY_TYPE_SOCKS5, 'localhost', 22, True)
sock.connect((**IP address of SSH server**, 22))
t = paramiko.Transport(sock)
t.connect( None, 'username', 'password')

并收到以下错误

> Traceback (most recent call last): ...
>     sock.connect((**IP address of SSH server**, 22))   File "C:\Python27\lib\site-packages\socks.py", line 368, in connect
>     _orgsocket.connect(self,(self.__proxy[1],portnum))   File "C:\Python27\lib\socket.py", line 224, in meth
>     return getattr(self._sock,name)(*args) socket.error: [Errno 10061] No connection could be made because the target machi ne actively
> refused it

我的目标是模拟Putty创建SSH SOCKS代理的方式,如下所示: Configure PuTTY To Create SSH SOCKS Proxy For Secure Browsing。 或等效的

  

ssh -D [localhost] port

用于本地动态应用程序级端口转发。

有人可以解释一下,有什么问题以及如何使用paramiko以正确的方式做到这一点? 感谢。

P.S。 我发现了这个https://stackoverflow.com/a/5823383/1264304但是,我没有成功实现它。有人?

1 个答案:

答案 0 :(得分:5)

Paramiko可以原生连接到ssh。您不需要SOCKS库来连接到ssh服务器。此外,当您尝试时,远程服务器拒绝连接,因为您没有进行身份验证。

这样做的正确方法是连接paramiko的sshClient

import paramiko
ssh = paramiko.SSHClient()
ssh.connect('yourServer', username='you', 
    password='yay!')

然后,获取基础transport

trans = ssh.get_transport()

最后,让ssh客户端使用open channel转发tcp端口:

trans.open_channel("forwarded-tcpip", dest_addr=('serverIP',8000), src_addr=('localhost'),8000))

这将导致本地端口8000上的任何连接通过此ssh会话远程转发到端口8000。