您现在的位置是:首页 >学无止境 >flask框架之 ---Flask-login网站首页学无止境

flask框架之 ---Flask-login

灰太狼家的小鸭子 2024-06-14 17:17:46
简介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中的登出进行操作。

风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。