本文整理匯總了Python中twisted.protocols.portforward.ProxyFactory方法的典型用法代碼示例。如果您正苦於以下問題:Python portforward.ProxyFactory方法的具體用法?Python portforward.ProxyFactory怎麽用?Python portforward.ProxyFactory使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類twisted.protocols.portforward
的用法示例。
在下文中一共展示了portforward.ProxyFactory方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: vtproxy
# 需要導入模塊: from twisted.protocols import portforward [as 別名]
# 或者: from twisted.protocols.portforward import ProxyFactory [as 別名]
def vtproxy():
reactor.listenTCP(lport, portforward.ProxyFactory(dhost, dport))
reactor.run()
示例2: makeService
# 需要導入模塊: from twisted.protocols import portforward [as 別名]
# 或者: from twisted.protocols.portforward import ProxyFactory [as 別名]
def makeService(config):
f = portforward.ProxyFactory(config['host'], int(config['dest_port']))
return strports.service(config['port'], f)
示例3: buildProtocol
# 需要導入模塊: from twisted.protocols import portforward [as 別名]
# 或者: from twisted.protocols.portforward import ProxyFactory [as 別名]
def buildProtocol(self, addr):
"""
Create the protocol instance, keeps track of it, and makes it use
C{clientFactoryInstance} as client factory.
"""
proto = portforward.ProxyFactory.buildProtocol(self, addr)
self.clientFactoryInstance = TestableProxyClientFactory()
# Force the use of this specific instance
proto.clientProtocolFactory = lambda: self.clientFactoryInstance
self.protoInstance = proto
return proto
示例4: test_registerProducers
# 需要導入模塊: from twisted.protocols import portforward [as 別名]
# 或者: from twisted.protocols.portforward import ProxyFactory [as 別名]
def test_registerProducers(self):
"""
The proxy client registers itself as a producer of the proxy server and
vice versa.
"""
# create a ProxyServer instance
addr = address.IPv4Address('TCP', '127.0.0.1', 0)
server = portforward.ProxyFactory('127.0.0.1', 0).buildProtocol(addr)
# set the reactor for this test
reactor = proto_helpers.MemoryReactor()
server.reactor = reactor
# make the connection
serverTransport = proto_helpers.StringTransport()
server.makeConnection(serverTransport)
# check that the ProxyClientFactory is connecting to the backend
self.assertEqual(len(reactor.tcpClients), 1)
# get the factory instance and check it's the one we expect
host, port, clientFactory, timeout, _ = reactor.tcpClients[0]
self.assertIsInstance(clientFactory, portforward.ProxyClientFactory)
# Connect it
client = clientFactory.buildProtocol(addr)
clientTransport = proto_helpers.StringTransport()
client.makeConnection(clientTransport)
# check that the producers are registered
self.assertIs(clientTransport.producer, serverTransport)
self.assertIs(serverTransport.producer, clientTransport)
# check the streaming attribute in both transports
self.assertTrue(clientTransport.streaming)
self.assertTrue(serverTransport.streaming)
示例5: starttcpproxy
# 需要導入模塊: from twisted.protocols import portforward [as 別名]
# 或者: from twisted.protocols.portforward import ProxyFactory [as 別名]
def starttcpproxy():
reactor.listenTCP(localport, portforward.ProxyFactory(desthost, destport))
reactor.run()
示例6: testPortforward
# 需要導入模塊: from twisted.protocols import portforward [as 別名]
# 或者: from twisted.protocols.portforward import ProxyFactory [as 別名]
def testPortforward(self):
serverProtocol = wire.Echo()
realServerFactory = protocol.ServerFactory()
realServerFactory.protocol = lambda: serverProtocol
realServerPort = reactor.listenTCP(0, realServerFactory,
interface='127.0.0.1')
proxyServerFactory = portforward.ProxyFactory('127.0.0.1',
realServerPort.getHost().port)
proxyServerPort = reactor.listenTCP(0, proxyServerFactory,
interface='127.0.0.1')
nBytes = 1000
received = []
clientProtocol = protocol.Protocol()
clientProtocol.dataReceived = received.extend
clientProtocol.connectionMade = lambda: clientProtocol.transport.write('x' * nBytes)
clientFactory = protocol.ClientFactory()
clientFactory.protocol = lambda: clientProtocol
reactor.connectTCP('127.0.0.1', proxyServerPort.getHost().port,
clientFactory)
c = 0
while len(received) < nBytes and c < 100:
reactor.iterate(0.01)
c += 1
self.assertEquals(''.join(received), 'x' * nBytes)
clientProtocol.transport.loseConnection()
serverProtocol.transport.loseConnection()
return defer.gatherResults([
defer.maybeDeferred(realServerPort.stopListening),
defer.maybeDeferred(proxyServerPort.stopListening)])