赞
踩
LoginManager是一个类,有多个方法和属性;此类初始化的对象用于保存用于登录的设置。实例:class:LoginManager
* *不绑定到特定应用程序,因此可以在代码的主体中创建一个,然后将其绑定到应用程序app中 工厂函数。
login-manager=LoginManager()
login_manager.init_app(app)
user_loader() 回调函数:
这将设置从会话重新加载用户的回调。 您设置的函数应该使用用户ID(“unicode”)并返回用户对象,如果用户不存在则返回“None”。
reload_user():
1、首先获取user id,如果获取不到有效的id,就将user设为anonymous user
2、获取到id后,再通过@login_manager.user_loader装饰的函数获取到user对象,如果没有获取到有效的user对象,就认为是anonymous user
3、最后将user保存于request context中(无论是正常的用户还是anonymous用户)
login_manager.login_view :验证失败后跳转的页面
login_manager.login_message:用户重定向到登录页面闪现的消息;
login_manager.refresh_view: 用户重新进行身份验证需要重定向的视图
login_manager.need_refresh_view::用户重定向到“需要刷新”页面时闪出的消息。
login_manager.session-protection:使用会话保护的模式。这可以是'basic'
(默认)或'strong'
,或None
禁用
@login_required:这是一个装饰器用来验证登录的用户是否正常。
- """权限访问"""
- def login_required(view):
- # 限制必须登录才能访问的页面装饰器
- @functools.wraps(view)
- def wrapped_view(**kwargs):
- if g.user is None:
- #给登录添加一个上次访问的url
- redirect_to=f"{url_for('auth.login')}?redirect_to={request.path}"
- return redirect(redirect_to)
-
- if g.user.has_prem:
- pass
- else:
- return '<h1>无权查看</h1>'
- return view(**kwargs)
-
- return wrapped_view
Login_user()
用户登录操作,用户在通过自定义的login视图函数,通过验证并登录成功后,login_user可以记录或者保存成功登录的用户。
logout_user()
登出功能类似,除了基本的操作外,还需要把flask-login中的登出进行操作。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。