Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/KeepSafe/aiohttp
Asynchronous HTTP client/server framework for asyncio and Python
https://github.com/KeepSafe/aiohttp
aiohttp async asyncio hacktoberfest http http-client http-server python
Last synced: 3 months ago
JSON representation
Asynchronous HTTP client/server framework for asyncio and Python
- Host: GitHub
- URL: https://github.com/KeepSafe/aiohttp
- Owner: aio-libs
- License: other
- Created: 2013-10-01T23:04:01.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2024-05-20T16:09:57.000Z (6 months ago)
- Last Synced: 2024-05-21T03:15:22.915Z (6 months ago)
- Topics: aiohttp, async, asyncio, hacktoberfest, http, http-client, http-server, python
- Language: Python
- Homepage: https://docs.aiohttp.org
- Size: 25 MB
- Stars: 14,625
- Watchers: 221
- Forks: 1,966
- Open Issues: 493
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGES.rst
- Contributing: CONTRIBUTING.rst
- Funding: .github/FUNDING.yml
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-asyncio - aiohttp - Http client/server for asyncio (PEP-3156). (Web Frameworks)
- my-awesome-starred - aiohttp - http client/server for asyncio (PEP-3156) (Python)
- awesome-asyncio - aiohttp - Http client/server for asyncio (PEP-3156). (Web Frameworks)
- awesome-asyncio-cn - aiohttp - 支持 Asyncio (PEP-3156) 的 HTTP 客户端/服务端网络库。 (Web框架)
README
==================================
Async http client/server framework
==================================.. image:: https://raw.githubusercontent.com/aio-libs/aiohttp/master/docs/aiohttp-plain.svg
:height: 64px
:width: 64px
:alt: aiohttp logo|
.. image:: https://github.com/aio-libs/aiohttp/workflows/CI/badge.svg
:target: https://github.com/aio-libs/aiohttp/actions?query=workflow%3ACI
:alt: GitHub Actions status for master branch.. image:: https://codecov.io/gh/aio-libs/aiohttp/branch/master/graph/badge.svg
:target: https://codecov.io/gh/aio-libs/aiohttp
:alt: codecov.io status for master branch.. image:: https://badge.fury.io/py/aiohttp.svg
:target: https://pypi.org/project/aiohttp
:alt: Latest PyPI package version.. image:: https://img.shields.io/pypi/dm/aiohttp
:target: https://pypistats.org/packages/aiohttp
:alt: Downloads count.. image:: https://readthedocs.org/projects/aiohttp/badge/?version=latest
:target: https://docs.aiohttp.org/
:alt: Latest Read The Docs.. image:: https://img.shields.io/matrix/aio-libs:matrix.org?label=Discuss%20on%20Matrix%20at%20%23aio-libs%3Amatrix.org&logo=matrix&server_fqdn=matrix.org&style=flat
:target: https://matrix.to/#/%23aio-libs:matrix.org
:alt: Matrix Room — #aio-libs:matrix.org.. image:: https://img.shields.io/matrix/aio-libs-space:matrix.org?label=Discuss%20on%20Matrix%20at%20%23aio-libs-space%3Amatrix.org&logo=matrix&server_fqdn=matrix.org&style=flat
:target: https://matrix.to/#/%23aio-libs-space:matrix.org
:alt: Matrix Space — #aio-libs-space:matrix.orgKey Features
============- Supports both client and server side of HTTP protocol.
- Supports both client and server Web-Sockets out-of-the-box and avoids
Callback Hell.
- Provides Web-server with middleware and pluggable routing.Getting started
===============Client
------To get something from the web:
.. code-block:: python
import aiohttp
import asyncioasync def main():
async with aiohttp.ClientSession() as session:
async with session.get('http://python.org') as response:print("Status:", response.status)
print("Content-type:", response.headers['content-type'])html = await response.text()
print("Body:", html[:15], "...")asyncio.run(main())
This prints:
.. code-block::
Status: 200
Content-type: text/html; charset=utf-8
Body: ...Coming from `requests `_ ? Read `why we need so many lines `_.
Server
------An example using a simple server:
.. code-block:: python
# examples/server_simple.py
from aiohttp import webasync def handle(request):
name = request.match_info.get('name', "Anonymous")
text = "Hello, " + name
return web.Response(text=text)async def wshandle(request):
ws = web.WebSocketResponse()
await ws.prepare(request)async for msg in ws:
if msg.type == web.WSMsgType.text:
await ws.send_str("Hello, {}".format(msg.data))
elif msg.type == web.WSMsgType.binary:
await ws.send_bytes(msg.data)
elif msg.type == web.WSMsgType.close:
breakreturn ws
app = web.Application()
app.add_routes([web.get('/', handle),
web.get('/echo', wshandle),
web.get('/{name}', handle)])if __name__ == '__main__':
web.run_app(app)Documentation
=============https://aiohttp.readthedocs.io/
Demos
=====https://github.com/aio-libs/aiohttp-demos
External links
==============* `Third party libraries
`_
* `Built with aiohttp
`_
* `Powered by aiohttp
`_Feel free to make a Pull Request for adding your link to these pages!
Communication channels
======================*aio-libs Discussions*: https://github.com/aio-libs/aiohttp/discussions
*Matrix*: `#aio-libs:matrix.org `_
We support `Stack Overflow
`_.
Please add *aiohttp* tag to your question there.Requirements
============- async-timeout_
- multidict_
- yarl_
- frozenlist_Optionally you may install the aiodns_ library (highly recommended for sake of speed).
.. _aiodns: https://pypi.python.org/pypi/aiodns
.. _multidict: https://pypi.python.org/pypi/multidict
.. _frozenlist: https://pypi.org/project/frozenlist/
.. _yarl: https://pypi.python.org/pypi/yarl
.. _async-timeout: https://pypi.python.org/pypi/async_timeoutLicense
=======``aiohttp`` is offered under the Apache 2 license.
Keepsafe
========The aiohttp community would like to thank Keepsafe
(https://www.getkeepsafe.com) for its support in the early days of
the project.Source code
===========The latest developer version is available in a GitHub repository:
https://github.com/aio-libs/aiohttpBenchmarks
==========If you are interested in efficiency, the AsyncIO community maintains a
list of benchmarks on the official wiki:
https://github.com/python/asyncio/wiki/Benchmarks