您现在的位置是:首页 >学无止境 >flask框架之 ---Flask-login网站首页学无止境
flask框架之 ---Flask-login
安装:pip3 install flask-login
介绍:
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中的登出进行操作。