成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

十個容易被忽視的FastAPI實用功能

開發 架構
IntelliJ IDEA:由于其廣泛的功能集和初始索引,IntelliJ的啟動時間可能稍長,特別是第一次啟動。但是,隨后的啟動通常會更快,這要歸功于優化的緩存機制。

簡介

FastAPI是一種現代、高性能的Python Web框架,用于構建Web應用程序和API。

它基于Python的異步編程庫asyncio和await語法,以及類型注解和自動文檔生成等特性,提供了快速、易用和可靠的開發體驗,接下來本文將介紹10項被忽視的FastAPI實用功能。

1. 依賴注入

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

2. 響應模型

使用Pydantic模型聲明響應結構。這將自動生成API文檔并驗證響應數據。

class User(BaseModel):
    id: int
    name: str

@app.get("/users/{user_id}", response_model=User)
def read_user(user_id: int): ...

3. HTTP異常

拋出帶有狀態代碼和詳細信息的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]}

4. 路徑參數和轉換器

使用轉換器將路徑參數轉換為所需的Python數據類型。

@app.get("/items/{item_id}")
def read_item(item_id: int): 
  ...

5. 后臺任務

將需要長期運行的任務委托給后臺,以釋放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"}

6. 查詢參數和字符串驗證

使用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

7. 帶密碼(和散列)的OAuth2和使用JWT令牌的Bearer

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"}

8. 使用Pydantic進行數據驗證和序列化

FastAPI使用Pydantic進行數據驗證和序列化,提供了一種處理錯誤和復雜類型的簡單方式。

class Item(BaseModel):
    name: str
    description: str

@app.post("/items/")
async def create_item(item: Item):
    return item

9. 使用Starlette的TestClient進行測試

FastAPI支持使用Starlette的TestClient編寫簡潔的測試用例。

from starlette.testclient import TestClient

def test_read_main():
    client = TestClient(app)
    response = client.get("/")
    assert response.status_code == 200

10. 自動交互式API文檔:

FastAPI通過Swagger UI和ReDoc提供自動交互式API文檔。只需訪問/docs或/redoc路由即可訪問這些文檔。

責任編輯:武曉燕 來源: Python學研大本營
相關推薦

2023-01-17 15:39:17

CSS功能函數

2024-02-29 07:48:55

Python編程語言上下文管理器

2011-03-07 10:51:34

FileZilla

2009-11-17 16:14:28

無線路由器

2012-11-28 15:53:16

災難恢復

2018-09-18 09:00:00

前端WebJavaScript

2023-11-06 18:02:28

Linux實用命令

2011-03-07 11:12:36

FileZilla

2009-11-09 09:57:39

交換機路由器

2011-03-07 09:20:02

FileZilla

2017-02-08 09:51:27

JavaScript細節

2023-03-07 15:50:35

2011-03-07 09:33:18

FileZilla

2010-05-25 09:02:21

Windows 7

2019-08-30 12:01:48

2017-08-15 17:09:31

Linux命令

2020-12-18 13:00:31

Xedit文本編輯器Linux

2010-01-22 15:45:57

局域網交換機

2017-11-27 12:08:10

后端服務spring mvc項目

2019-01-18 13:22:10

布線事項網絡
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产91中文 | 亚洲一区二区中文字幕在线观看 | 91精品国产一区二区 | 欧美在线天堂 | 久久精品一区二区三区四区 | 国产精品久久久久婷婷二区次 | 色精品| 在线观看亚洲精品视频 | www.99精品 | 亚洲精品自在在线观看 | 天堂在线1 | 羞羞的视频免费在线观看 | www.99re| 国产美女在线免费观看 | 天天操精品视频 | 一区二区亚洲 | 99国产精品久久久久老师 | 欧美午夜精品理论片a级按摩 | 久久亚洲精品国产精品紫薇 | 久久久www成人免费无遮挡大片 | 99热在线播放 | 国产在线a | 成人在线视频免费观看 | 3级毛片| 国产精品99久久久久久动医院 | 欧美大片一区 | 精精国产xxxx视频在线 | 久久久久久久久久影视 | 久久欧美精品 | 国产精品视频免费观看 | 91精品国产一二三 | 日本一区二区三区免费观看 | 欧美精品网 | 亚洲精品一区二区三区在线观看 | 在线精品国产 | 一区二区影院 | 亚洲国产一区二区在线 | 精品国产一区二区三区久久久蜜月 | 国产精品视频一区二区三区 | 国产成人久久av免费高清密臂 | 视频第一区 |