本文整理匯總了Python中multidict.CIMultiDict方法的典型用法代碼示例。如果您正苦於以下問題:Python multidict.CIMultiDict方法的具體用法?Python multidict.CIMultiDict怎麽用?Python multidict.CIMultiDict使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類multidict
的用法示例。
在下文中一共展示了multidict.CIMultiDict方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: __init__
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def __init__(self, status, content, headers=None):
self.status = status
if headers is None:
self.headers = CIMultiDict()
if content is not None and type(content) == bytes:
self.headers["Content-Type"] = "application/octet-stream"
else:
self.headers["Content-Type"] = "text/html"
else:
if type(headers) == str:
self.headers = CIMultiDict([("Content-Type", headers)])
else:
self.headers = headers
self.content = content
示例2: Response
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def Response(method="GET", status=200, body=b"***"):
response = LoggedClientResponse(method, URL("/"), **_respkw())
response.status = status
response.reason = ""
response.code = status
response.should_close = False
response._headers = CIMultiDict({})
response._raw_headers = []
class Body:
async def read(self):
return body
def unread_data(self, data):
if body == b"":
err = AttributeError(
"'EmptyStreamReader' object has no " "attribute 'unread_data'"
)
raise err
pass
response.content = Body()
response._content = body
return response
示例3: from_request
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def from_request(cls, request, status_code, status_message, payload=None, headers=None):
if not headers:
headers = CIMultiDict()
if 'Via' not in headers:
headers['Via'] = request.headers['Via']
return Response(
status_code=status_code,
status_message=status_message,
cseq=request.cseq,
method=request.method,
headers=headers,
from_details=request.from_details,
to_details=request.to_details,
contact_details=request.contact_details,
payload=payload,
)
示例4: fromRequestWillBeSent
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def fromRequestWillBeSent (self, req):
""" Set request data from Chrome Network.requestWillBeSent event """
r = req['request']
self.id = req['requestId']
self.url = URL (r['url'])
self.resourceType = req.get ('type')
self._time = ReferenceTimestamp (req['timestamp'], req['wallTime'])
assert self.request is None, req
self.request = Request ()
self.request.initiator = req['initiator']
self.request.headers = CIMultiDict (self._unfoldHeaders (r['headers']))
self.request.hasPostData = r.get ('hasPostData', False)
self.request.method = r['method']
self.request.timestamp = self._time (req['timestamp'])
if self.request.hasPostData:
postData = r.get ('postData')
if postData is not None:
self.request.body = UnicodeBody (postData)
示例5: test_parse_type_one_error
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def test_parse_type_one_error(self):
self.requested_name = 'something/'
self.detection = {"type": 1}
self.expected_content = None
self.headers = multidict.CIMultiDict()
self.status_code = 404
async def test():
(self.res1, self.res2, self.res3) = \
await self.handler.parse_tanner_response(
self.requested_name, self.detection)
self.loop.run_until_complete(test())
real_result = [self.res1, self.res2, self.res3]
expected_result = [self.expected_content, self.headers, self.status_code]
self.assertCountEqual(real_result, expected_result)
示例6: test_parse_type_two_with_headers
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def test_parse_type_two_with_headers(self):
self.detection = {
"type": 2,
"payload": {
"page": "",
"value": "test.png",
"headers": {
"content-type": "multipart/form-data",
},
},
}
self.expected_content = b'test.png'
self.content_type = 'image/png'
self.headers = multidict.CIMultiDict([("Content-Type", "multipart/form-data")])
async def test():
(self.res1, self.res2, self.res3) = \
await self.handler.parse_tanner_response(
self.requested_name, self.detection)
self.loop.run_until_complete(test())
real_result = [self.res1, self.res2, self.res3]
expected_result = [self.expected_content, self.headers, self.status_code]
self.assertCountEqual(real_result, expected_result)
示例7: test_parse_type_three
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def test_parse_type_three(self):
self.detection = {
"type": 3,
"payload": {
"page": "/index.html",
"value": "test",
"status_code": 200,
},
}
self.expected_content = None
self.headers = multidict.CIMultiDict()
async def test():
(self.res1, self.res2, self.res3) = \
await self.handler.parse_tanner_response(
self.requested_name, self.detection)
self.loop.run_until_complete(test())
real_result = [self.res1, self.res2, self.res3]
expected_result = [self.expected_content, self.headers, self.status_code]
self.assertCountEqual(real_result, expected_result)
示例8: __init__
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def __init__(self, *,
status: int=200,
reason: Optional[str]=None,
headers: Optional[LooseHeaders]=None) -> None:
self._body = None
self._keep_alive = None # type: Optional[bool]
self._chunked = False
self._compression = False
self._compression_force = None # type: Optional[ContentCoding]
self._cookies = SimpleCookie()
self._req = None # type: Optional[BaseRequest]
self._payload_writer = None # type: Optional[AbstractStreamWriter]
self._eof_sent = False
self._body_length = 0
self._state = {} # type: Dict[str, Any]
if headers is not None:
self._headers = CIMultiDict(headers) # type: CIMultiDict[str]
else:
self._headers = CIMultiDict() # type: CIMultiDict[str]
self.set_status(status, reason)
示例9: _prepare_headers
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def _prepare_headers(
self,
headers: Optional[LooseHeaders]) -> 'CIMultiDict[str]':
""" Add default headers and transform it to CIMultiDict
"""
# Convert headers to MultiDict
result = CIMultiDict(self._default_headers)
if headers:
if not isinstance(headers, (MultiDictProxy, MultiDict)):
headers = CIMultiDict(headers)
added_names = set() # type: Set[str]
for key, value in headers.items():
if key in added_names:
result.add(key, value)
else:
result[key] = value
added_names.add(key)
return result
示例10: on_headers_complete
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def on_headers_complete(self):
remote_addr = self.transport.get_extra_info('peername')
if remote_addr:
self.headers.append(('Remote-Addr', '%s:%s' % remote_addr))
#
# 構建 HTTP 請求
#
self.request = Request(
url_bytes=self.url,
headers=CIMultiDict(self.headers),
version=self.parser.get_http_version(),
method=self.parser.get_method().decode()
)
#
# HTTP 請求: 寫入 body 部分
#
示例11: do_parser
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def do_parser(body, body_bytes, resp_headers, url, crawler):
if len(body) > int(config.read('Multiprocess', 'ParseInBurnerSize')):
stats.stats_sum('parser in burner thread', 1)
# headers is a multidict.CIMultiDictProxy case-blind dict
# and the Proxy form of it doesn't pickle, so convert to one that does
resp_headers = multidict.CIMultiDict(resp_headers)
links, embeds, sha1, facets, base = await crawler.burner.burn(
partial(do_burner_work_html, body, body_bytes, resp_headers,
burn_prefix='burner ', url=url),
url=url)
else:
stats.stats_sum('parser in main thread', 1)
# no coroutine state because this is a burn, not an await
links, embeds, sha1, facets, base = do_burner_work_html(
body, body_bytes, resp_headers, burn_prefix='main ', url=url)
return links, embeds, sha1, facets, base
示例12: __init__
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def __init__(self, *, status=200, reason=None, headers=None):
self._body = None
self._keep_alive = None
self._chunked = False
self._compression = False
self._compression_force = False
self._cookies = SimpleCookie()
self._req = None
self._payload_writer = None
self._eof_sent = False
self._body_length = 0
if headers is not None:
self._headers = CIMultiDict(headers)
else:
self._headers = CIMultiDict()
self.set_status(status, reason)
示例13: _prepare_headers
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def _prepare_headers(self, headers):
""" Add default headers and transform it to CIMultiDict
"""
# Convert headers to MultiDict
result = CIMultiDict(self._default_headers)
if headers:
if not isinstance(headers, (MultiDictProxy, MultiDict)):
headers = CIMultiDict(headers)
added_names = set()
for key, value in headers.items():
if key in added_names:
result.add(key, value)
else:
result[key] = value
added_names.add(key)
return result
示例14: __init__
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def __init__(
self,
application,
use_cookies: bool = True,
timeout: Optional[Union[int, float]] = None,
headers: Optional[Union[dict, CIMultiDict]] = None,
scope: Optional[dict] = None,
):
self.application = guarantee_single_callable(application)
self.cookie_jar: Optional[
SimpleCookie
] = SimpleCookie() if use_cookies else None
self.timeout = timeout
self.headers = headers or {}
self._scope = scope or {}
self._lifespan_input_queue: asyncio.Queue[dict] = asyncio.Queue()
self._lifespan_output_queue: asyncio.Queue[dict] = asyncio.Queue()
示例15: __init__
# 需要導入模塊: import multidict [as 別名]
# 或者: from multidict import CIMultiDict [as 別名]
def __init__(self, *, body: Optional[Union[bytes, str]] = None, status: int = 200, reason: Optional[str] = None, headers: Optional[Union[Dict, CIMultiDict, CIMultiDictProxy]] = None, content_type: Optional[str] = None, charset: Optional[str] = None) -> None:
if headers is None:
headers = CIMultiDict()
elif not isinstance(headers, (CIMultiDict, CIMultiDictProxy)):
headers = CIMultiDict(headers)
self._body = body
self._status = status
self._reason = reason
self._headers = headers
self.content_type = content_type if hdrs.CONTENT_TYPE not in headers else None
self.charset = charset if hdrs.CONTENT_TYPE not in headers else None
self.missing_content_type = hdrs.CONTENT_TYPE not in headers and not content_type and not charset