《每天5分钟用Flask搭建一个管理系统》 第7章:用户认证

第7章:用户认证

7.1 用户认证的重要性

用户认证是确定用户身份的过程,它是任何需要用户登录的应用的关键部分。认证确保只有经过验证的用户才能访问受限资源。

7.2 Flask-Login扩展的使用

Flask-Login提供了用户会话管理的简单方法。它处理用户登录和登出,并可以记住用户登录状态。

示例代码:安装Flask-Login

bash 复制代码
pip install flask-login

示例代码:配置Flask-Login

python 复制代码
from flask_login import LoginManager

login_manager = LoginManager()
login_manager.init_app(app)

# 设置用户加载函数
@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))
7.3 用户注册和登录流程

用户注册是创建新用户账户的过程,而登录是用户验证其身份的过程。

示例代码:用户注册

python 复制代码
from flask import render_template, redirect, url_for, flash
from flask_login import login_user

@app.route('/register', methods=['GET', 'POST'])
def register():
    if request.method == 'POST':
        # 假设有表单数据username和password
        user = User(username=request.form['username'], password=hashed_password)
        db.session.add(user)
        db.session.commit()
        flash('Your account has been created!', 'success')
        return redirect(url_for('login'))
    return render_template('register.html')

示例代码:用户登录

python 复制代码
from flask_login import login_user, current_user, logout_user

@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        user = User.query.filter_by(username=request.form['username']).first()
        if user and user.check_password(request.form['password']):
            login_user(user)
            next_page = request.args.get('next')
            return redirect(next_page) if next_page else redirect(url_for('index'))
        else:
            flash('Login Unsuccessful. Please check username and password', 'danger')
    return render_template('login.html')
7.4 用户会话管理

用户会话管理包括登录、登出和记住用户状态。

示例代码:用户登出

python 复制代码
@app.route('/logout')
def logout():
    logout_user()
    return redirect(url_for('index'))

示例代码:记住用户状态

python 复制代码
from flask_login import remember_cookie_permanent

@app.route('/remember')
@login_required
def remember_me():
    remember_cookie_permanent()
    return 'Remember Me cookie set'
7.5 保护路由

您可以使用@login_required装饰器来保护需要用户登录才能访问的路由。

示例代码:保护路由

python 复制代码
from flask_login import login_required

@app.route('/dashboard')
@login_required
def dashboard():
    return render_template('dashboard.html')
7.6 总结

本章介绍了用户认证的重要性,以及如何使用Flask-Login扩展来管理用户注册、登录、登出和会话。

相关推荐
山川而川-R4 分钟前
windows系统安装labelimg按“W”键报错
python
qq_12498707534 分钟前
基于Spring Boot的心理咨询预约微信小程序(源码+论文+部署+安装)
java·spring boot·后端·spring·微信小程序·小程序·毕业设计
袁袁袁袁满5 分钟前
OpenAI SDK集成亮数据网页解锁器实现自动化爬虫
爬虫·python·ai·网络爬虫·爬虫实战·自动化爬虫·ai爬虫
哈哈不让取名字6 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
仰望星空@脚踏实地7 分钟前
Python 中subprocess.getstatusoutput(cmd) 函数注入命令风险分析
python·datakit·getstatusoutput
深蓝电商API7 分钟前
Scrapy 自定义命令与扩展:打造专属爬虫工具
爬虫·python·scrapy
郝学胜-神的一滴8 分钟前
机器学习数据预处理:深入理解标准化与sklearn的StandardScaler
开发语言·人工智能·python·程序人生·机器学习·sklearn
@fai9 分钟前
[特殊字符] 在 PyQt6 中实现 Photoshop 风格的“橡皮擦”光标:高性能、不随缩放变形、精准跟随鼠标
图像处理·python·pyqt·photoshop
彭于晏Yan9 分钟前
SpringBoot集成Druid连接多个数据源
java·spring boot·后端
hssfscv16 分钟前
Javaweb学习笔记——后端实战6登录功能1
笔记·后端·学习