當前位置: 首頁>>代碼示例>>Python>>正文


Python proxy.ProxyClient方法代碼示例

本文整理匯總了Python中twisted.web.proxy.ProxyClient方法的典型用法代碼示例。如果您正苦於以下問題:Python proxy.ProxyClient方法的具體用法?Python proxy.ProxyClient怎麽用?Python proxy.ProxyClient使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在twisted.web.proxy的用法示例。


在下文中一共展示了proxy.ProxyClient方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: makeProxyClient

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def makeProxyClient(self, request, method=b"GET", headers=None,
                        requestBody=b""):
        """
        Make a L{ProxyClient} object used for testing.

        @param request: The request to use.
        @param method: The HTTP method to use, GET by default.
        @param headers: The HTTP headers to use expressed as a dict. If not
            provided, defaults to {'accept': 'text/html'}.
        @param requestBody: The body of the request. Defaults to the empty
            string.
        @return: A L{ProxyClient}
        """
        if headers is None:
            headers = {b"accept": b"text/html"}
        path = b'/' + request.postpath
        return ProxyClient(
            method, path, b'HTTP/1.0', headers, requestBody, request) 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:20,代碼來源:test_proxy.py

示例2: assertForwardsHeaders

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def assertForwardsHeaders(self, proxyClient, requestLine, headers):
        """
        Assert that C{proxyClient} sends C{headers} when it connects.

        @param proxyClient: A L{ProxyClient}.
        @param requestLine: The request line we expect to be sent.
        @param headers: A dict of headers we expect to be sent.
        @return: If the assertion is successful, return the request body as
            bytes.
        """
        self.connectProxy(proxyClient)
        requestContent = proxyClient.transport.value()
        receivedLine, receivedHeaders, body = self._parseOutHeaders(
            requestContent)
        self.assertEqual(receivedLine, requestLine)
        self.assertEqual(receivedHeaders, headers)
        return body 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:19,代碼來源:test_proxy.py

示例3: makeProxyClient

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def makeProxyClient(self, request, method="GET", headers=None,
                        requestBody=""):
        """
        Make a L{ProxyClient} object used for testing.

        @param request: The request to use.
        @param method: The HTTP method to use, GET by default.
        @param headers: The HTTP headers to use expressed as a dict. If not
            provided, defaults to {'accept': 'text/html'}.
        @param requestBody: The body of the request. Defaults to the empty
            string.
        @return: A L{ProxyClient}
        """
        if headers is None:
            headers = {"accept": "text/html"}
        path = '/' + request.postpath
        return ProxyClient(
            method, path, 'HTTP/1.0', headers, requestBody, request) 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:20,代碼來源:test_proxy.py

示例4: assertForwardsHeaders

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def assertForwardsHeaders(self, proxyClient, requestLine, headers):
        """
        Assert that C{proxyClient} sends C{headers} when it connects.

        @param proxyClient: A L{ProxyClient}.
        @param requestLine: The request line we expect to be sent.
        @param headers: A dict of headers we expect to be sent.
        @return: If the assertion is successful, return the request body as
            bytes.
        """
        self.connectProxy(proxyClient)
        requestContent = proxyClient.transport.value()
        receivedLine, receivedHeaders, body = self._parseOutHeaders(
            requestContent)
        self.assertEquals(receivedLine, requestLine)
        self.assertEquals(receivedHeaders, headers)
        return body 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:19,代碼來源:test_proxy.py

示例5: connectProxy

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def connectProxy(self, proxyClient):
        """
        Connect a proxy client to a L{StringTransportWithDisconnection}.

        @param proxyClient: A L{ProxyClient}.
        @return: The L{StringTransportWithDisconnection}.
        """
        clientTransport = StringTransportWithDisconnection()
        clientTransport.protocol = proxyClient
        proxyClient.makeConnection(clientTransport)
        return clientTransport 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:13,代碼來源:test_proxy.py

示例6: test_forward

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def test_forward(self):
        """
        When connected to the server, L{ProxyClient} should send the saved
        request, with modifications of the headers, and then forward the result
        to the parent request.
        """
        return self._testDataForward(
            200, b"OK", [(b"Foo", [b"bar", b"baz"])], b"Some data\r\n") 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:10,代碼來源:test_proxy.py

示例7: test_headersCleanups

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def test_headersCleanups(self):
        """
        The headers given at initialization should be modified:
        B{proxy-connection} should be removed if present, and B{connection}
        should be added.
        """
        client = ProxyClient(b'GET', b'/foo', b'HTTP/1.0',
            {b"accept": b"text/html", b"proxy-connection": b"foo"}, b'', None)
        self.assertEqual(client.headers,
            {b"accept": b"text/html", b"connection": b"close"}) 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:12,代碼來源:test_proxy.py

示例8: test_buildProtocol

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def test_buildProtocol(self):
        """
        L{ProxyClientFactory.buildProtocol} should produce a L{ProxyClient}
        with the same values of attributes (with updates on the headers).
        """
        factory = ProxyClientFactory(b'GET', b'/foo', b'HTTP/1.0',
                                     {b"accept": b"text/html"}, b'Some data',
                                     None)
        proto = factory.buildProtocol(None)
        self.assertIsInstance(proto, ProxyClient)
        self.assertEqual(proto.command, b'GET')
        self.assertEqual(proto.rest, b'/foo')
        self.assertEqual(proto.data, b'Some data')
        self.assertEqual(proto.headers,
                          {b"accept": b"text/html", b"connection": b"close"}) 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:17,代碼來源:test_proxy.py

示例9: __init__

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def __init__(self, *args, **kwargs):
			self.intercept = {'song': b'/eapi/v3/song/detail/', 'search': b'/eapi/cloudsearch/pc', 'url': b'/eapi/song/enhance/player/url', 'album': b'/eapi/v1/album', 'artist': b'/eapi/v1/artist', 'playlist': b'/eapi/v3/playlist/detail', 'discovery': b'/eapi/v1/discovery/new/songs', 'linux': b'/api/linux/forward'}
			self.interval = {self.intercept['song']: 10, self.intercept['search']: 100, 'default': 10}
			self.temp_buffer = {self.intercept['song']: None, self.intercept['search']: None}
			self.timestamp = {self.intercept['song']: time.time(), self.intercept['search']: time.time()}
			proxy.ProxyClient.__init__(self, *args, **kwargs) 
開發者ID:yi-ji,項目名稱:NeteaseMusicAbroad,代碼行數:8,代碼來源:NeteaseMusicProxy.py

示例10: handleResponsePart

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def handleResponsePart(self, buffer):
			if self.rest in [self.intercept['song'], self.intercept['search'], self.intercept['playlist'], self.intercept['discovery'], self.intercept['linux']] or self.intercept['album'] in self.rest or self.intercept['artist'] in self.rest:
				print(self.headers)
				if self.headers[b'content-length'] != mainland_proxy.url_request_length:
					print('response intercepted: ', self.rest)
					if self.rest not in self.timestamp:
						self.timestamp[self.rest] = time.time()
						self.temp_buffer[self.rest] = None
					if time.time() - self.timestamp[self.rest] > self.interval.get(self.rest, self.interval['default']):
						self.temp_buffer[self.rest] = 0
						self.timestamp[self.rest] = time.time()
					if self.temp_buffer[self.rest] != None:
						buffer = self.temp_buffer[self.rest] + buffer
					buffer_str = sh_gzip_decompress(buffer)
					if buffer_str == None or b'unexpected end of file' in buffer_str:
						self.temp_buffer[self.rest] = buffer
						self.timestamp[self.rest] = time.time()
						return
					else:
						del self.temp_buffer[self.rest]
						del self.timestamp[self.rest]
					buffer_str = modify_response(buffer_str)
					#print buffer_str
					buffer = sh_gzip_compress(buffer_str)
			if self.rest == self.intercept['url']:
				self.check_buffer(buffer)
			proxy.ProxyClient.handleResponsePart(self, buffer) 
開發者ID:yi-ji,項目名稱:NeteaseMusicAbroad,代碼行數:29,代碼來源:NeteaseMusicProxy.py

示例11: handleResponsePart

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def handleResponsePart(self, buffer):
        #Buffer the output if we intend to modify it
        if self.father.has_response_modifiers():
            self.father.response_buffer.write(buffer)
        else:
            proxy.ProxyClient.handleResponsePart(self, buffer) 
開發者ID:pdjstone,項目名稱:wsuspect-proxy,代碼行數:8,代碼來源:intercepting_proxy.py

示例12: handleResponseEnd

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def handleResponseEnd(self):
        #Process the buffered output if we are modifying it
        if self.father.has_response_modifiers():
            if not self._finished:
                #Replace the StringIO with a string for the modifiers
                data = self.father.response_buffer.getvalue()
                self.father.response_buffer.close()
                self.father.response_buffer = data

                #Do editing of response headers / content here
                self.father.run_response_modifiers()
                self.father.responseHeaders.setRawHeaders('content-length', [len(self.father.response_buffer)])
                self.father.write(self.father.response_buffer)
        proxy.ProxyClient.handleResponseEnd(self) 
開發者ID:pdjstone,項目名稱:wsuspect-proxy,代碼行數:16,代碼來源:intercepting_proxy.py

示例13: handleHeader

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def handleHeader(self, key, value):
        proxy.ProxyClient.handleHeader(self, key, value)
        if key.lower() == b'content-type':
            if value.decode().split(';')[0] == 'text/html':
                self.parser = WordParser() 
開發者ID:ScrappyZhang,項目名稱:python_web_Crawler_DA_ML_DL,代碼行數:7,代碼來源:t48_http_proxy_wordcount.py

示例14: handleResponsePart

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def handleResponsePart(self, buffer):
        proxy.ProxyClient.handleResponsePart(self, buffer)
        if hasattr(self, 'parser'):
            self.parser.feed(buffer.decode())
            self.father.wordCounter.addWords(self.parser.getWords())
            del self.parser 
開發者ID:ScrappyZhang,項目名稱:python_web_Crawler_DA_ML_DL,代碼行數:8,代碼來源:t48_http_proxy_wordcount.py

示例15: handleHeader

# 需要導入模塊: from twisted.web import proxy [as 別名]
# 或者: from twisted.web.proxy import ProxyClient [as 別名]
def handleHeader(self, key, value):
        if (key.lower() == "content-type" and
                value == "application/vnd.docker.raw-stream"):
            self._handleRawStream()
        return proxy.ProxyClient.handleHeader(self, key, value) 
開發者ID:ClusterHQ,項目名稱:powerstrip,代碼行數:7,代碼來源:powerstrip.py


注:本文中的twisted.web.proxy.ProxyClient方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。