g
是本地线程,并且是每个请求的内容(请参阅代理说明)。该session
是还当地一个线程,但在默认情况下被保存到一个MAC-签署cookie,并发送给客户端。
你遇到的问题是,session
每个请求都将重建该请求(因为该请求已发送给客户端,并且客户端将其发送回给我们),而设置的数据g仅在此请求的生命周期内可用。
在最简单的事情(注意simple != secure
-如果你需要确保看看烧瓶登录)是简单地将用户的ID添加到会话,并加载每个请求的用户:
@app.before_request
def load_user():
if session["user_id"]:
user = User.query.filter_by(username=session["user_id"]).first()
else:
user = {"name": "Guest"} # Make it better, use an anonymous User instead
g.user = user