def register_exception(app: FastAPI):
"""
全局异常捕获
:param app:
:return:
"""
# 捕获参数 验证错误
@app.exception_handler(RequestValidationError)
async def validation_exception_handler(request: Request, exc: RequestValidationError):
"""
捕获请求参数 验证错误
:param request:
:param exc:
:return:
"""
logger.error(f"参数错误\nURL:{request.url}\nHeaders:{request.headers}\n{traceback.format_exc()}")
return JSONResponse(
status_code=status.HTTP_400_BAD_REQUEST,
content=jsonable_encoder({"code": 10002, "data": {"tip": exc.errors()}, "body": exc.body,
"message": "参数不全或参数错误"}),
)
# 捕获全部异常
@app.exception_handler(Exception)
async def all_exception_handler(request: Request, exc: Exception):
logger.error(f"全局异常\nURL:{request.url}\nHeaders:{request.headers}\n{traceback.format_exc()}")
return JSONResponse(
status_code=status.HTTP_500_INTERNAL_SERVER_ERROR,
content={"code": 500, "data": {"tip": "服务器错误"}, "message": "fail"},
)
# 捕获断言错误,用于返回错误状态
@app.exception_handler(AssertionError)
async def asser_exception_handler(request: Request, exc: AssertionError):
logger.error(f"断言错误,URL:{request.url}, 此处条件不符合")
logger.info(f"------------------------{exc.args}")
state = exc.args[0] if exc.args else 0
return JSONResponse(res(state=state))
def register_cors(app: FastAPI):
"""
支持跨域
:param app:
:return:
"""
app.add_middleware(
CORSMiddleware,
allow_origin_regex='https?://.*', # 改成用正则就行了
allow_credentials=True,
allow_methods=["*"],
allow_headers=["*"],
)
def register_middleware(app: FastAPI):
"""
请求响应拦截
:param app:
:return:
"""
@app.middleware("http")
async def logger_request(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(round(process_time, 5))
logger.info(f"访问记录:{request.method} url:{request.url} 耗时:{str(round(process_time, 5))}")
return response
fastapi-关于异常捕获,请求响应拦截等中间件
最新推荐文章于 2025-03-12 11:10:43 发布