本文整理匯總了Python中aiohttp.TCPConnector方法的典型用法代碼示例。如果您正苦於以下問題:Python aiohttp.TCPConnector方法的具體用法?Python aiohttp.TCPConnector怎麽用?Python aiohttp.TCPConnector使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類aiohttp
的用法示例。
在下文中一共展示了aiohttp.TCPConnector方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: create_session
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def create_session(self, loop):
conn = None
if self.proxy and self.proxy_user:
conn = aiohttp.ProxyConnector(
loop=loop,
limit=self.parallel,
proxy=self.proxy,
proxy_auth=aiohttp.BasicAuth(self.proxy_user, self.proxy_password)
)
elif self.proxy:
conn = aiohttp.ProxyConnector(loop=loop, limit=self.parallel, proxy=self.proxy)
else:
conn = aiohttp.TCPConnector(loop=loop, limit=self.parallel)
session = aiohttp.ClientSession(connector=conn)
return session
示例2: run
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def run(self, host):
tasks = []
# 默認limit=100,enable_cleanup_closed設置為True防止ssl泄露,ttl_dns_cache調高dns緩存
conn = aiohttp.TCPConnector(
limit=LIMIT,
enable_cleanup_closed=True,
ttl_dns_cache=100,
ssl=False,
)
timeout = aiohttp.ClientTimeout(total=60, connect=2)
async with aiohttp.ClientSession(connector=conn, timeout=timeout) as session:
for url in self.urls:
task = asyncio.ensure_future(self.scan(host, url, session))
tasks.append(task)
# gather方法是所有請求完成後才有輸出
_ = await asyncio.gather(*tasks)
# for i in asyncio.as_completed(tasks): # 類似於線程池中的task一樣
# answer = await i
# 創建啟動任務
示例3: _request
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def _request(self, callback, method, uri, data=None, headers=None):
connector = aiohttp.TCPConnector(loop=self._loop,
verify_ssl=self.verify)
async with aiohttp.ClientSession(connector=connector) as session:
self._session = session
resp = await session.request(method=method,
url=uri,
data=data,
headers=headers)
body = await resp.text(encoding='utf-8')
content = await resp.read()
if resp.status == 599:
raise base.Timeout
r = base.Response(resp.status, resp.headers, body, content)
await session.close()
return callback(r)
# python prior 3.4.1 does not play nice with __del__ method
示例4: get_http_client
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def get_http_client(app):
""" get http client """
if "client" in app:
return app["client"]
# first time call, create client interface
# use shared client so that all client requests
# will share the same connection pool
if "loop" not in app:
raise KeyError("loop not initialized")
loop = app["loop"]
max_tcp_connections = int(config.get("max_tcp_connections"))
log.info(f"Initiating TCPConnector with limit {max_tcp_connections} connections")
client = ClientSession(loop=loop, connector=TCPConnector(limit_per_host=max_tcp_connections))
#create the app object
app['client'] = client
return client
示例5: __init__
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def __init__(self, loop, console, verbose=0, statsd=None, **kw):
connector = kw.pop("connector", None)
if connector is None:
connector = TCPConnector(loop=loop, limit=None)
super(LoggedClientSession, self).__init__(
loop=loop,
request_class=LoggedClientRequest,
response_class=LoggedClientResponse,
connector=connector,
**kw
)
self.console = console
self.request_class = LoggedClientRequest
self.request_class.verbose = verbose
self.verbose = verbose
self.request_class.session = self
self.request_class.response_class = LoggedClientResponse
self.statsd = statsd
self.eventer = EventSender(
console, [StdoutListener(verbose=self.verbose, console=self.console)]
)
示例6: aiohttp_session
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def aiohttp_session(*, auth: Optional[Auth] = None, **kwargs: Any) -> ClientSession:
headers = {'User-Agent': USER_AGENT}
if auth:
headers['Authorization'] = auth.encode()
# setup SSL
cafile = config.get('ca')
if not cafile:
cafile = certifi.where()
ssl_context = create_default_context(cafile=cafile)
try:
connector = TCPConnector(ssl=ssl_context)
except TypeError:
connector = TCPConnector(ssl_context=ssl_context)
return ClientSession(headers=headers, connector=connector, **kwargs)
示例7: test_connect
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def test_connect(proxy,operator,mode=None):
conn = aiohttp.TCPConnector(verify_ssl=False)
async with ClientSession(connector=conn) as s:
try:
async with s.get(url=TEST_URL,proxy=proxy[2],
timeout=10,allow_redirects=False) as resp:
page = await resp.text()
if (resp.status != 200 or str(resp.url) != TEST_URL):
utils.log(('[INFO]#proxy:{ip} has been dropped\n'
' #Reason:Abnormal url or return Code').format(ip=proxy[1]))
operator.del_proxy_with_id(config.free_ipproxy_table,proxy[0])
operator.del_proxy_with_id(config.httpbin_table,proxy[0])
elif mode == 'add':
operator.insert_valid_proxy(id=proxy[0])
else:
operator.update_valid_proxy(id=proxy[0])
except Exception as e:
utils.log(('[INFO]#proxy:{ip} has been dropped\n'
' #Reason:{msg}').format(ip=proxy[1],msg=str(e)))
operator.del_proxy_with_id(config.free_ipproxy_table,proxy[0])
operator.del_proxy_with_id(config.httpbin_table,proxy[0])
finally:
operator.commit()
示例8: async_fetch
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def async_fetch(cls, urls, descs=None, cb=None, datas=None, fds=None):
if descs is None:
descs = []
if datas is None:
datas = []
if fds is None:
fds = []
conn = aiohttp.TCPConnector(limit_per_host=cls.CONNECTIONS_PER_HOST)
async with aiohttp.ClientSession(
connector=conn,
headers={'User-Agent': cls.USER_AGENT}
) as session:
coros = [
asyncio.ensure_future(cls._async_fetch_one(session, url, desc, cb, data, fd))
for url, desc, data, fd in zip_longest(urls, descs, datas, fds)
]
with tqdm(asyncio.as_completed(coros),
total=len(coros),
desc="Downloading", unit="files") as t:
result = [await coro for coro in t]
return result
示例9: _async_loop
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def _async_loop(self, urls):
"""Asynchronous internal method used to request multiple URLs
Args:
urls (list): URLs to fetch
Returns:
responses (obj): All URL requests' response coroutines
"""
results = []
async with aiohttp.ClientSession(
connector=aiohttp.TCPConnector(ssl=False)
) as session:
for url in urls:
result = asyncio.ensure_future(self._get_async(url, session))
results.append(result)
responses = await asyncio.gather(*results)
return responses
示例10: test_connector_factory
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def test_connector_factory(es_params, loop):
class TCPConnector(aiohttp.TCPConnector):
used = False
def __init__(self, *args, **kwargs):
TCPConnector.used = True
super(TCPConnector, self).__init__(*args, **kwargs)
tr = Transport(
endpoints=[{'host': es_params['host']}],
sniffer_interval=None,
loop=loop,
connector_factory=lambda: TCPConnector(loop=loop)
)
assert 1 == len(tr._pool.connections)
assert TCPConnector.used
tr.close()
示例11: __awaitable__
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def __awaitable__(self):
if self._data is None:
async with aiohttp.ClientSession(connector=aiohttp.TCPConnector(verify_ssl=self.api.verify_ssl)) as session:
wait_time = self._wait_time()
if wait_time is None and self.api:
try:
await self._make_async_request(session)
except ServiceUnavailableException:
await asyncio.sleep(60)
self._wait_time()
await self._make_async_request(session)
else:
await asyncio.sleep(wait_time)
await self._make_async_request(session)
return self
示例12: start
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def start(self, host: str = "127.0.0.1", port: int = 8080) -> None:
connector = None
self.log.debug(f"Starting appservice web server on {host}:{port}")
if self.server.startswith("https://") and not self.verify_ssl:
connector = aiohttp.TCPConnector(verify_ssl=False)
self._http_session = aiohttp.ClientSession(loop=self.loop, connector=connector)
self._intent = AppServiceAPI(base_url=self.server, bot_mxid=self.bot_mxid, log=self.log,
token=self.as_token, state_store=self.state_store,
real_user_content_key=self.real_user_content_key,
client_session=self._http_session).bot_intent()
ssl_ctx = None
if self.tls_cert and self.tls_key:
ssl_ctx = ssl.create_default_context(ssl.Purpose.CLIENT_AUTH)
ssl_ctx.load_cert_chain(self.tls_cert, self.tls_key)
self.runner = web.AppRunner(self.app)
await self.runner.setup()
site = web.TCPSite(self.runner, host, port, ssl_context=ssl_ctx)
await site.start()
示例13: _init_session
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def _init_session(self):
_safe = self.settings.SPIDER_COOKIES_UNSAFE_MODE
path = self.settings.SPIDER_COOKIES_LOAD_PATH
_c_cookies = self.settings.SPIDER_COOKIES_CUSTOM
jar = aiohttp.CookieJar(unsafe=_safe)
if _c_cookies:
cookies = _c_cookies
else:
cookies = None
self.conn = aiohttp.TCPConnector(limit=self.settings.CONCURRENCY)
self.session = aiohttp.ClientSession(connector=self.conn,
cookies=cookies,
cookie_jar=jar)
if path:
if os.path.exists(path):
try:
self.session.cookie_jar.load(path)
if cookies:
self.session.cookie_jar.update_cookies(cookies)
except:
return
self.logger.debug(f'Loaded [{self.name}] cookie jar.')
示例14: cloudfare_session
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def cloudfare_session(loop):
sessions = []
async def go(**kwargs):
fake = FakeCloudfare(**kwargs)
info = await fake.start()
resolver = FakeResolver(info, loop=asyncio.get_event_loop())
connector = aiohttp.TCPConnector(resolver=resolver,
ssl=False)
session = aiohttp.ClientSession(connector=connector)
sessions.append(session)
return session
yield go
for s in sessions:
loop.run_until_complete(s.close())
示例15: test_secure_ok
# 需要導入模塊: import aiohttp [as 別名]
# 或者: from aiohttp import TCPConnector [as 別名]
def test_secure_ok(aiohttp_client, aiohttp_server, ssl_ctx):
async def handler(request):
return web.Response()
app = web.Application()
app.router.add_get('/', handler)
await _setup(app, Secure())
srv = await aiohttp_server(app, ssl=ssl_ctx)
conn = aiohttp.TCPConnector(ssl=False)
cl = await aiohttp_client(srv, connector=conn)
resp = await cl.get('/')
print(resp.request_info.url)
assert resp.status == 200
assert resp.headers['X-Frame-Options'] == 'DENY'
expected = 'max-age=31536000; includeSubDomains'
assert resp.headers['Strict-Transport-Security'] == expected
assert resp.headers['X-Content-Type-Options'] == 'nosniff'
assert resp.headers['X-XSS-Protection'] == '1; mode=block'