首页 > 解决方案 > Flask 登录“current_user”会话已过期

问题描述

我正在使用 Flask Login + Slack 构建用户身份验证。在回调 url 中,应用成功获取login(user)并且current_user. 但是重定向后,current_user已经过期了...

我的代码:

应用程序/auth.py

@bp.route('/callback', methods=["GET", "POST"])
def callback():
    auth_code = request.args['code']
    client = slack.WebClient(token="")
    oauth_info = client.oauth_access(
        client_id=client_id,
        client_secret=client_secret,
        code=auth_code
    )

    access_token = oauth_info['access_token']
    client = slack.WebClient(token=access_token)
    user_id = oauth_info['user_id']
    response = client.users_info(user=user_id)

    login_user(user)
    print(current_user)
    // <User 'XXXXXXXXXX'>
    return redirect(url_for('user.show', cat=user.uid))

auth.pycurrent_user已成功获取。

应用程序/用户.py

from flask_login import current_user

@bp.route('/<cat>')
def show(cat):
    print(current_user)
    // <flask_login.mixins.AnonymousUserMixin object at XXXXXX>
    return render_template('user/show.html)

user.py,它未能得到current_user

应用程序/__init__.py

# login manager
login_manager = LoginManager()
login_manager.init_app(app)
login_manager.login_view =  "auth.callback"

@login_manager.user_loader
def load_user(user_id):
    try:
        return User.query.get(user_id)
    except:
        return None

标签: pythonflaskflask-login

解决方案


我错过了current_user在 LoginManager 中的设置。

# login manager
login_manager = LoginManager()
login_manager.init_app(app)
login_manager.login_view =  "auth.callback"

@login_manager.user_loader
def load_user(user_id):
    user = db.find_user_by_id(user_id)
    return user

推荐阅读