我正在使用Flask Login + Slack构建用户身份验证。在回调URL中,应用成功获取了login(user)
和current_user
。但是重定向后,current_user
已过期...
我的代码:
app / 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.py
中,已成功获得current_user
。
app / 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
。
app / __ 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
我错过了在LoginManager中设置current_user
的时间。
# 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