【问题标题】:FastAPI OAuth2PasswordRequestForm dependency causing request failureFastAPI OAuth2PasswordRequestForm 依赖导致请求失败
【发布时间】:2020-11-08 04:57:18
【问题描述】:

我正在使用 FastAPI 的 user guide(JWT/Bearer 令牌)中详述的身份验证方案。当我尝试从/token 端点获取令牌时,请求在路径操作函数运行之前失败。这是有问题的函数:

async def login_for_access_token(form_data: OAuth2PasswordRequestForm = Depends(), session: SessionLocal = Depends(get_db)):
    user = authenticate_user(session, form_data.username, form_data.password)
    if not user:
        raise HTTPException(
            status_code=status.HTTP_401_UNAUTHORIZED,
            detail="Incorrect username or password",
            headers={"WWW-Authenticate": "Bearer"},
        )
    access_token = create_access_token(data={"sub": user.id})
    return {"access_token": access_token, "token_type": "bearer"}

我通常使用断点来帮助找出在这些情况下出了什么问题,但是在函数中的任何代码实际运行之前调用就失败了,这让我相信问题出在OAuth2PasswordRequestForm 依赖项上。我通过禁用form_data parameter 验证了这是问题所在,并且能够执行完整的请求。

我得到的错误在细节上很少。这是我在控制台中得到的:INFO: 127.0.0.1:52261 - "POST /token HTTP/1.1" 400 Bad Request

这是我在 Swagger UI 中看到的内容:

这在本教程中使用的单文件格式对我有用,但我已经将内容分解为不同的文件以保持我的大型项目井井有条。我有一种感觉,我只是在重新组织这段代码时错过了一些东西,但似乎无法弄清楚是什么原因造成的。

【问题讨论】:

    标签: python authentication oauth jwt fastapi


    【解决方案1】:

    当然,这个问题的解决方案在the docs。问题是我缺少 python-multipart 依赖项。我刚刚运行 pip install python-multipart 并重新启动了我的服务器,然后我就能够进行身份验证了。

    【讨论】:

    • 我已经安装了这个,但仍然有同样的问题!有什么想法吗?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2013-05-22
    • 2018-09-18
    • 2019-04-07
    • 2022-10-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多