三.Flask 登录[flask-login]

一.登录

1.基础

1.1 下载

格式:pip install flask-login

1.2加密密码

  1. 导入:from werkzeug.security import generate_password_hash,check_password_hash
  2. 加密:generate_password_hash('1234dada56')

1.3对比密码

格式:check_password_hash(pw, '1234dada56')

2.开始

导入:from flask_login import LoginManager

初始化

login_manager = LoginManager()
login_manager.init_app(app)

必要渲染器

@login_manager.user_loader
def load_user(user_id):
    user= Database.query.get(int(user_id))
    return user
# 其会在页面打开时加载为下面验证用户身份做准备

必要继承类

class Database(db.Model, UserMixin):
# 数据库要继承UserMixin

3.保护路由

3.1基本

导入:from flask_login import login_required
写法:@login_required


@app.route('/jk')
@login_required
def jkl():
    return '登录用户可以查询的'

前提:login_user(user) #在用户密码验证成功后使用

3.2未登录用户跳转

格式:login_manager.login_view = 'show_index' #引号是视图函数的名称

3.3回到被登录保护的那一页

return redirect(next)
# 通过前端获得,因为被重定向url里面会写着从哪里过来

4.记住登录信息

格式:login_user(user,true) #默认记住一年,主要就是这个true
自定义:app.config['PERMANENT_SESSION_LIFETIME'] = datetime.timedelta(days=360)

5.退出登录

格式:logout_user()

6.判断是否登录

在这里插入图片描述
格式:current_user.is_authenticated #需要导入current_user

  1. current_user:需要获取当登录用户的信息

7. 自定义修饰器

格式:

def aa(func):
    def ii():
        print(current_user)
        return func()
    return ii
@login_bp.route('/l', methods=["GET"])
@login_required
@aa
def lllll():
    return '123'

解释: aa(fuc)中的fuc指的就是def lllll():函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值