2

我创建了一个登录路径,在其中发布我的表单数据并设置一个 cookie。设置 cookie 后,我重定向到“/main”{detail:"Method Not Allowed"}作为响应。

@app.post("/login")
async def login(request:Request):
     response = RedirectResponse(url="/main")
     response.set_cookie(key="cookie",value="key-value")
     return response

@app.get("/main")
async def root(request:Request, cookie: Optional[str] = Cookie(None)):
     if cookie:
        answer = "set to %s" % cookie
     else:
          answer = "not set"

     return {"value": answer}

我进一步检查了控制台,发现在重定向期间向“/main”发出了 POST 请求,因此导致了错误。当我将其更改为它时,app.post("/main")它工作正常。如何避免此错误?我不想每次都发布访问“/main”的请求。提前致谢。

4

1 回答 1

4

我发现在 FastAPI 中,starlette 响应默认具有代码 307,它在重定向期间保留了方法,因此保留了 post 请求。我通过response.status_code = 302在返回响应之前添加解决了这个问题。

于 2021-04-01T12:32:44.113 回答