2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
Starlette allows you to install custom exception handlers to deal with
|
|
|
|
how you return responses when errors or handled exceptions occur.
|
2018-09-04 10:52:29 +00:00
|
|
|
|
|
|
|
```python
|
2018-11-08 11:59:15 +00:00
|
|
|
from starlette.applications import Starlette
|
|
|
|
from starlette.responses import HTMLResponse
|
2018-09-04 10:52:29 +00:00
|
|
|
|
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
HTML_404_PAGE = ...
|
|
|
|
HTML_500_PAGE = ...
|
2018-09-04 10:52:29 +00:00
|
|
|
|
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
app = Starlette()
|
2018-09-04 10:52:29 +00:00
|
|
|
|
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
@app.exception_handler(404)
|
|
|
|
async def not_found(request, exc):
|
2019-01-21 09:29:34 +00:00
|
|
|
return HTMLResponse(content=HTML_404_PAGE, status_code=exc.status_code)
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
@app.exception_handler(500)
|
|
|
|
async def server_error(request, exc):
|
2019-01-21 09:29:34 +00:00
|
|
|
return HTMLResponse(content=HTML_500_PAGE, status_code=exc.status_code)
|
2018-09-04 10:52:29 +00:00
|
|
|
```
|
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
If `debug` is enabled and an error occurs, then instead of using the installed
|
|
|
|
500 handler, Starlette will respond with a traceback response.
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
```python
|
|
|
|
app = Starlette(debug=True)
|
2018-09-04 10:52:29 +00:00
|
|
|
```
|
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
As well as registering handlers for specific status codes, you can also
|
|
|
|
register handlers for classes of exceptions.
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
In particular you might want to override how the built-in `HTTPException` class
|
|
|
|
is handled. For example, to use JSON style responses:
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
```python
|
|
|
|
@app.exception_handler(HTTPException)
|
|
|
|
async def http_exception(request, exc):
|
|
|
|
return JSONResponse({"detail": exc.detail}, status_code=exc.status_code)
|
|
|
|
```
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
## Errors and handled exceptions
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
It is important to differentiate between handled exceptions and errors.
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
Handled exceptions do not represent error cases. They are coerced into appropriate
|
|
|
|
HTTP responses, which are then sent through the standard middleware stack. By default
|
|
|
|
the `HTTPException` class is used to manage any handled exceptions.
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
Errors are any other exception that occurs within the application. These cases
|
|
|
|
should bubble through the entire middleware stack as exceptions. Any error
|
|
|
|
logging middleware should ensure that it re-raises the exception all the
|
|
|
|
way up to the server.
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
In order to deal with this behaviour correctly, the middleware stack of a
|
|
|
|
`Starlette` application is configured like this:
|
2018-09-04 10:52:29 +00:00
|
|
|
|
2018-11-08 11:59:15 +00:00
|
|
|
* `ServerErrorMiddleware` - Returns 500 responses when server errors occur.
|
|
|
|
* Installed middleware
|
|
|
|
* `ExceptionMiddleware` - Deals with handled exceptions, and returns responses.
|
|
|
|
* Router
|
|
|
|
* Endpoints
|
2018-09-04 10:52:29 +00:00
|
|
|
|
|
|
|
## HTTPException
|
|
|
|
|
|
|
|
The `HTTPException` class provides a base class that you can use for any
|
2018-11-08 11:59:15 +00:00
|
|
|
handled exceptions. The `ExceptionMiddleware` implementation defaults to
|
|
|
|
returning plain-text HTTP responses for any `HTTPException`.
|
2018-09-04 10:52:29 +00:00
|
|
|
|
|
|
|
* `HTTPException(status_code, detail=None)`
|
2018-11-08 11:59:15 +00:00
|
|
|
|
|
|
|
You should only raise `HTTPException` inside routing or endpoints. Middleware
|
|
|
|
classes should instead just return appropriate responses directly.
|