fastapi依赖注入,非常重要,项目使用地方token验证

from fastapi import FastAPI,Depends

from typing import Optional
import uvicorn
app = FastAPI()
# 函数依赖注入方法
def  page_index_size(page_index:Optional[int] = 1,page_size:Optional[int]=10):
    return {
        'page_index': page_index,
        'page_size': page_size
    }
# 依赖注入
@app.get('/item')
async  def item_data(page_info:dict=Depends(page_index_size)):

       return {
           'page_index':page_info.get('page_index'),
           'page_size': page_info.get('page_size')
       }

# 类依赖注入方法
class  PageInfo:
     def __init__(self,page_index:Optional[int]=1,page_size:Optional[int]=10):
          self.page_index = page_index
          self.page_size = page_size

@app.get('/items')
async def create_page(page_info:PageInfo=Depends(PageInfo)):
    return {
        'page_index': page_info.page_index,
        'page_size': page_info.page_size
    }

# 类依赖注入省略写方法
class  PageInfo1:
     def __init__(self,page_index:Optional[int]=1,page_size:Optional[int]=10):
          self.page_index = page_index
          self.page_size = page_size

@app.get('/goods')
async def create_page1(page_info:PageInfo1=Depends()):
    return {
        'page_index': page_info.page_index,
        'page_size': page_info.page_size,

    }




# 三级联动注入用法
# 函数依赖注入方法
def  total_page(total_pages:Optional[int]=10):
    return total_pages
def  page_index_size1(page_index:Optional[int] = 1,page_size:Optional[int]=10,total:Optional[int] = Depends(total_page)):
    return {
        'page_index': page_index,
        'page_size': page_size,
        'total':total
    }
# 依赖注入
@app.get('/itemUser')
async  def item_data1(page_info:dict=Depends(page_index_size1)):

       return {
           'page_index':page_info.get('page_index'),
           'page_size': page_info.get('page_size'),
           'total':page_info.get('total')
       }
if __name__ == '__main__':
    uvicorn.run('main:app',port=10001,reload=True)

### 如何在 FastAPI 中实现基于 Token依赖注入 为了实现在 FastAPI 应用程序中的基于 Token依赖注入,通常需要定义一个依赖函数来处理 Token 验证逻辑。这个过程涉及创建一个依赖项,该依赖项负责解析请求头中的 `Authorization` 字段并验证所提供的 Token 是否有效。 #### 定义依赖函数 首先,定义一个用于提取和验证 Token 的依赖函数: ```python from fastapi import Depends, HTTPException, status from fastapi.security import OAuth2PasswordBearer oauth2_scheme = OAuth2PasswordBearer(tokenUrl="token") def get_current_user(token: str = Depends(oauth2_scheme)): # 这里应放置实际的Token验证逻辑 credentials_exception = HTTPException( status_code=status.HTTP_401_UNAUTHORIZED, detail="Could not validate credentials", headers={"WWW-Authenticate": "Bearer"}, ) user_data = verify_token(token) # 假设有一个verify_token方法来进行具体验证 if not user_data: raise credentials_exception return user_data ``` 上述代码片段展示了如何通过 `Depends()` 来指定 `get_current_user` 函数作为一个依赖项[^1]。当此依赖被调用时,FastAPI 将自动从请求头部读取名为 `Authorization` 的字段,并将其传递给 `OAuth2PasswordBearer` 对象实化过程中所设置的路径 `/token` 获取访问令牌。 #### 使用依赖于路径操作函数 一旦有了这样的依赖函数,在任何希望保护其免受未授权访问影响的操作中都可以轻松应用它。只需简地将依赖添加为参数即可: ```python @app.get("/users/me", response_model=User) async def read_users_me(current_user: User = Depends(get_current_user)): return current_user ``` 这里展示了一个简的 GET 请求处理器,它返回当前登录用户的个人信息。注意这里的 `current_user` 参数是如何利用前面定义好的 `get_current_user` 作为依赖传入的[^2]。 这种模式不仅简化了认证流程的设计,还使得应用程序更易于维护和发展,因为所有的身份验证逻辑都被集中在一个地方管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值