我创建了一个登录路径,在其中发布表单数据并设置 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”的发布请求。提前致谢。
我发现在 FastAPI 中,starlette 响应默认具有代码 307,它在重定向期间保留该方法,因此保留了 post 请求。我通过添加解决了这个问题response.status_code = 302
在返回响应之前。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)