.. _using_http2: Using HTTP/2 ============ `HTTP/2 `__ is the second major version of the Hyper Text Transfer Protocol used to transfer web data. .. note:: Not all ASGI Servers support HTTP/2. The recommended ASGI server, Hypercorn, does. To use HTTP/2 in development you will need to create some SSL certificates and run Quart with SSL. Server push or push promises ---------------------------- With `HTTP/2 `__ the server can choose to pre-emptively push additional responses to the client, this is termed a server push and the response itself is called a push promise. Server push is very useful when the server knows the client will likely initiate a request, say for the css or js referenced in a html response. .. note:: Browsers are deprecating support for server push, and usage is not recommended. This section is kept for reference. In Quart server push can be initiated during a request via the function :func:`~quart.helpers.make_push_promise`, for example, .. code-block:: python async def index(): await make_push_promise(url_for('static', filename='css/minimal.css')) return await render_template('index.html') The push promise will include (copy) header values present in the request that triggers the push promise. These are to ensure that the push promise is responded too as if the request had made it. A good example is the ``Accept`` header. The full set of copied headers are ``SERVER_PUSH_HEADERS_TO_COPY`` in the request module. .. note:: This functionality is only useable with ASGI servers that implement the ``HTTP/2 Server Push`` extension. If the server does not support this extension Quart will ignore the push promises (as with HTTP/1 connections). Hypercorn, the recommended ASGI server, supports this extension. When testing server push,the :class:`~quart.testing.QuartClient` ``push_promises`` list will contain every push promise as a tuple of the path and headers, for example, .. code-block:: python async def test_push_promise(): test_client = app.test_client() await test_client.get("/push") assert test_client.push_promises[0] == ("/", {}) HTTP/2 clients -------------- At the time of writing there aren't that many HTTP/2 clients. The best option is to use a browser and inspect the network connections (turn on the protocol information). Otherwise curl can be used, if HTTP/2 support is `installed `_, as so, .. code-block:: console $ curl --http2 ... If you wish to communicate via HTTP/2 in python `httpx `_ is the best choice.