Tri*_*eat 5 python starlette fastapi uvicorn
我正在尝试在 fastapi 中间件中验证令牌,但这似乎是不可能的。因为我认为中间件需要进行下一次调用,尽管它不是必需的。我无法在这个 python-fastapi 后端找到任何好的解决方案来一次性处理令牌。任何帮助表示赞赏。
@app.middleware("http")
async def add_middleware_here(request: Request, call_next):
token = request.headers["Authorization"]
try:
verification_of_token = verify_token(token)
if verification_of_token:
response = await call_next(request)
return response
except InvalidSignatureError as er:
raise HTTPException(status_code=401)
Run Code Online (Sandbox Code Playgroud)
您需要返回响应。我会告诉你如何让它工作:
from fastapi.responses import JSONResponse
@app.middleware("http")
async def add_middleware_here(request: Request, call_next):
token = request.headers["Authorization"]
try:
verification_of_token = verify_token(token)
if verification_of_token:
response = await call_next(request)
return response
else:
return JSONResponse(status_code=403) # or 401
except InvalidSignatureError as er:
return JSONResponse(status_code=401)
Run Code Online (Sandbox Code Playgroud)
请注意,使用此中间件意味着您的 API 上没有登录路由(用于生成令牌)。
此外,您应该考虑使用此依赖项:https : //fastapi.tiangolo.com/tutorial/security/simple-oauth2/
另一件事是您可以使用fastapi.status作为您的状态代码。
请参阅JSONResponse API文档。
from fastapi.responses import JSONResponse
@app.middleware("http")
async def errors_handling(request: Request, call_next):
try:
return await call_next(request)
except Exception as exc:
return JSONResponse(status_code=500, content={'reason': str(exc)})
Run Code Online (Sandbox Code Playgroud)