FastAPI是一种现代、高性能的Python Web框架,用于构建Web应用程序和API。
为乌苏等地区用户提供了全套网页设计制作服务,及乌苏网站建设行业解决方案。主营业务为成都网站制作、成都网站设计、外贸营销网站建设、乌苏网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
它基于Python的异步编程库asyncio和await语法,以及类型注解和自动文档生成等特性,提供了快速、易用和可靠的开发体验,接下来本文将介绍10项被忽视的FastAPI实用功能。
FastAPI支持定义“依赖项”,这些依赖项会被解析并注入到路径操作中。使用这个功能处理常见任务,如数据库连接或用户身份验证。
def get_db():
db = SessionLocal()
try:
yield db
finally:
db.close()
@app.get("/users/{user_id}")
def read_user(user_id: int, db: Session = Depends(get_db)):
user = db.query(User).get(user_id)
return user
使用Pydantic模型声明响应结构。这将自动生成API文档并验证响应数据。
class User(BaseModel):
id: int
name: str
@app.get("/users/{user_id}", response_model=User)
def read_user(user_id: int): ...
抛出带有状态代码和详细信息的HTTP异常,以处理不同的HTTP状态代码。
@app.get("/items/{item_id}")
def read_item(item_id: str):
if item_id not in items:
raise HTTPException(status_code=404, detail="Item not found")
return {"item": items[item_id]}
使用转换器将路径参数转换为所需的Python数据类型。
@app.get("/items/{item_id}")
def read_item(item_id: int):
...
将需要长期运行的任务委托给后台,以释放API的响应时间。
@app.post("/send-notification/{email}")
async def send_notification(email: str, background_tasks: BackgroundTasks):
background_tasks.add_task(send_email, email=email)
return {"message": "Notification sent in the background"}
使用Query声明字符串查询参数和验证。
@app.get("/items/")
async def read_items(q: Optional[str] = Query(None, max_length=50)):
results = {"items": [{"item_id": "Foo"}]}
if q:
results.update({"q": q})
return results
FastAPI内置了OAuth2密码和Bearer,用于处理用户注册、登录和令牌检索的所有路径。
@app.post("/token", response_model=Token)
def login_for_access_token(form_data: OAuth2PasswordRequestForm = Depends()):
user = authenticate_user(fake_users_db, form_data.username, form_data.password)
if not user:
raise HTTPException(status_code=400, detail="Incorrect username or password")
access_token_expires = timedelta(minutes=ACCESS_TOKEN_EXPIRE_MINUTES)
access_token = create_access_token(
data={"sub": user.username}, expires_delta=access_token_expires
)
return {"access_token": access_token, "token_type": "bearer"}
FastAPI使用Pydantic进行数据验证和序列化,提供了一种处理错误和复杂类型的简单方式。
class Item(BaseModel):
name: str
description: str
@app.post("/items/")
async def create_item(item: Item):
return item
FastAPI支持使用Starlette的TestClient编写简洁的测试用例。
from starlette.testclient import TestClient
def test_read_main():
client = TestClient(app)
response = client.get("/")
assert response.status_code == 200
FastAPI通过Swagger UI和ReDoc提供自动交互式API文档。只需访问/docs或/redoc路由即可访问这些文档。
网站名称:十个容易被忽视的FastAPI实用功能
文章分享:http://www.shufengxianlan.com/qtweb/news44/516044.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联