committed by
GitHub
3 changed files with 70 additions and 0 deletions
@ -0,0 +1,15 @@ |
|||||
|
import time |
||||
|
|
||||
|
from fastapi import FastAPI |
||||
|
from starlette.requests import Request |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
|
||||
|
@app.middleware("http") |
||||
|
async def add_process_time_header(request: Request, call_next): |
||||
|
start_time = time.time() |
||||
|
response = await call_next(request) |
||||
|
process_time = time.time() - start_time |
||||
|
response.headers["X-Process-Time"] = str(process_time) |
||||
|
return response |
@ -0,0 +1,54 @@ |
|||||
|
You can add middleware to **FastAPI** applications. |
||||
|
|
||||
|
A "middleware" is a function that works with every **request** before it is processed by any specific *path operation*. And also with every **response** before returning it. |
||||
|
|
||||
|
* It takes each **request** that comes to your application. |
||||
|
* It can then do something to that **request** or run any needed code. |
||||
|
* Then it passes the **request** to be processed by the rest of the application (by some *path operation*). |
||||
|
* It then takes the **response** generated by the application (by some *path operation*). |
||||
|
* It can do something to that **response** or run any needed code. |
||||
|
* Then it returns the **response**. |
||||
|
|
||||
|
## Create a middleware |
||||
|
|
||||
|
To create a middleware you use the decorator `@app.middleware("http")` on top of a function. |
||||
|
|
||||
|
The middleware function receives: |
||||
|
|
||||
|
* The `request`. |
||||
|
* A function `call_next` that will receive the `request` as a parameter. |
||||
|
* This function will pass the `request` to the corresponding *path operation*. |
||||
|
* Then it returns the `response` generated by the corresponding *path operation*. |
||||
|
* You can then modify further the `response` before returning it. |
||||
|
|
||||
|
```Python hl_lines="9 10 12 15" |
||||
|
{!./src/middleware/tutorial001.py!} |
||||
|
``` |
||||
|
|
||||
|
!!! tip |
||||
|
This technique is used in the tutorial about <a href="https://fastapi.tiangolo.com/tutorial/sql-databases/" target="_blank">SQL (Relational) Databases</a>. |
||||
|
|
||||
|
### Before and after the `response` |
||||
|
|
||||
|
You can add code to be run with the `request`, before any *path operation* receives it. |
||||
|
|
||||
|
And also after the `response` is generated, before returning it. |
||||
|
|
||||
|
For example, you could add a custom header `X-Process-Time` containing the time in seconds that it took to process the request and generate a response: |
||||
|
|
||||
|
```Python hl_lines="11 13 14" |
||||
|
{!./src/middleware/tutorial001.py!} |
||||
|
``` |
||||
|
|
||||
|
## Starlette's Middleware |
||||
|
|
||||
|
You can also add any other <a href="https://www.starlette.io/middleware/" target="_blank">Starlette Middleware</a>. |
||||
|
|
||||
|
These are classes instead of plain functions. |
||||
|
|
||||
|
Including: |
||||
|
|
||||
|
* `CORSMiddleware` (described in the next section). |
||||
|
* `GZipMiddleware`. |
||||
|
* `SentryMiddleware`. |
||||
|
* ...and others. |
Loading…
Reference in new issue