FastAPI中的Request和Response是用于处理HTTP请求和响应的两个核心对象。它们提供了许多功能和属性,使你能够更灵活地处理和构建HTTP请求和响应
Request
你可以在视图函数中声明一个变量,并指定类型为Request,那么你就可以操作这个Request对象了。如下:
from fastapi import Request
@app.get("/home")
async def home(request: Request):
print(type(request), request)
return {
'code': 1}
Request具有如下属性:
app: 程序入口对象,即FastAPI对象url: 获取当前完整的url,默认情况下返回一个starlette.datastructures.URL对象。例如:http://localhost:8000/home?name=laozhangbase_url: 获取请求的路径,默认情况下返回一个starlette.datastructures.URL对象。例如:http://localhost:8000/headers: 获取请求的标头,默认情况下返回一个starlette.datastructures.Headers对象query_params: 获取查询参数,默认情况下返回一个starlette.datastructures.QueryParams对象path_params: 路径参数,默认情况下返回一个dict类型cookies: cookie信息,默认情况下返回一个dict类型client: 客户端信息,默认情况下返回一个starlette.datastructures.Address类型。例如:Address(host='127.0.0.1', port=63902)session: session信息,默认情况下返回一个dict类型。值得注意的是,在FastAPI中,使用session需要使用到starlette-session库,并且需要将SessionMiddleware添加到中间件中,否则将会引发报错,使用如下:
from redis import Redis
from fastapi import FastAPI
from fastapi import Request
from starlette_session import SessionMiddleware
from starlette_session.backends import BackendType
app = FastAPI()
r = Redis.from_url("redis://:12345678@localhost:6379/1")
app.add_middleware(
SessionMiddleware,
secret_key="secret",
cookie_name="cookie22",
backend_type=BackendType.redis,
backend_client=r
)
@app.get("/home")
async def home(request: Request):
print(type(request.session), request.session)
return {

本文详细介绍了FastAPI中的请求(Request)和响应(Response)对象,包括它们的属性、方法以及各种类型的响应如HTMLResponse、JSONResponse等。Request对象提供了访问HTTP请求的各个部分的能力,如URL、标头、查询参数等。Response对象则允许你构建并返回不同的HTTP响应,包括设置状态码、内容类型以及处理JSON、HTML、文件等内容。
最低0.47元/天 解锁文章
645

被折叠的 条评论
为什么被折叠?



