当前位置: 首页 > news >正文

一个简洁高效的Flask用户管理示例

Flask-Login 是 Flask 的用户管理扩展,提供 用户身份验证、会话管理、权限控制 等功能。

适用于

• 用户登录、登出

• 记住用户(“记住我” 功能)

• 限制未登录用户访问某些页面

• 用户会话管理

 1. 安装 Flask-Login

pip install flask-login flask-sqlalchemy

main.py

from flask import Flask, render_template, redirect, url_for, request, flash
from flask_sqlalchemy import SQLAlchemy
from flask_login import LoginManager, UserMixin, login_user, logout_user, login_required, current_user

app = Flask(__name__)

# 配置 Flask 和数据库
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///users.db'  # 使用 SQLite 数据库
app.config['SECRET_KEY'] = 'your_secret_key'  # Flask-Login 需要 secret key
db = SQLAlchemy(app)
login_manager = LoginManager(app)

# 定义用户模型
class User(UserMixin, db.Model):  # UserMixin 提供 Flask-Login 必需的方法
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(100), unique=True, nullable=False)
    password = db.Column(db.String(200), nullable=False)  # 真实应用需加密密码

# 创建数据库表(仅需运行一次)
with app.app_context():
    db.create_all()

# Flask-Login 加载用户的回调函数
@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))  # 通过 ID 获取用户


@app.route('/register', methods=['GET', 'POST'])
def register():
    if request.method == 'POST':
        username = request.form.get('username')
        password = request.form.get('password')

        if not username or not password:
            flash("用户名和密码不能为空!")
            return redirect(url_for('register'))

        # 检查用户是否已存在
        existing_user = User.query.filter_by(username=username).first()
        if existing_user:
            flash("用户名已存在,请选择其他用户名")
            return redirect(url_for('register'))

        # 创建新用户并保存到数据库
        new_user = User(username=username, password=password)  # 这里应加密密码
        db.session.add(new_user)
        db.session.commit()

        flash("注册成功,请登录!")
        return redirect(url_for('login'))

    return render_template('register.html')


@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        username = request.form.get('username')
        password = request.form.get('password')

        # 查找用户
        user = User.query.filter_by(username=username).first()
        if user and user.password == password:  # 这里应使用加密密码验证
            login_user(user)  # 登录用户
            flash("登录成功!")
            return redirect(url_for('dashboard'))

        flash("用户名或密码错误")
        return redirect(url_for('login'))

    return render_template('login.html')


@app.route('/dashboard')
@login_required  # 保护此路由,未登录用户无法访问
def dashboard():
    return f"欢迎 {current_user.username}!这是您的仪表盘。 <a href='/logout'>登出</a>"


@app.route('/logout')
@login_required
def logout():
    logout_user()
    flash("您已成功退出!")
    return redirect(url_for('login'))


if __name__ == "__main__":
    app.run(debug=True)

templates/login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form method="post">
    <label>用户名:</label>
    <input type="text" name="username" required>
    <label>密码:</label>
    <input type="password" name="password" required>
    <button type="submit">登录</button>
</form>
</body>
</html>

templates/register.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form method="post">
      <label>用户名:</label>
      <input type="text" name="username" required>
      <label>密码:</label>
      <input type="password" name="password" required>
      <button type="submit">注册</button>
    </form>
</body>
</html>

运行,然后访问:

• 注册:http://127.0.0.1:5000/register

• 登录:http://127.0.0.1:5000/login

• 仪表盘(必须登录):http://127.0.0.1:5000/dashboard

• 登出:http://127.0.0.1:5000/logout

相关文章:

  • C++--STL库-List
  • 华为昇腾服务器部署deepseek的坑
  • QT移植,交叉编译至泰山派RK3566开发板,.pro文件解析
  • Docker安装Minio对象存储
  • 文 章 索 引
  • MySQL——数据库约束
  • 智能博弈与体系对抗
  • Golang 面试题
  • C#从零开始学习(图文教程),持续更新中~
  • Docker报错:https://registry-1.docker.io/v2/
  • TexTCNN
  • 【MySQL系列文章】Linux环境下安装部署MySQL
  • 基于 Java + SSM + JSP 的百货中心供应链管理系统设计与实现
  • 用deepseek学大模型04-机器学习建模过程
  • 排序与算法:选择排序
  • MySQL的基本使用
  • 了解SQL Server不同版本(如Express、Standard、Enterprise)的功能差异和适用场景。
  • LLM论文笔记 12: Teaching Arithmetic to Small Transformers
  • Linux-C/C++《C/7、字符串处理》(字符串输入/输出、C 库中提供的字符串处理函数、正则表达式等)
  • WordPress Ai插件:支持提示词生成文章和chat智能对话
  • 经济日报金观平:促进信贷资金畅达小微企业
  • 《风林火山》千呼万唤始出来,戛纳首映后口碑崩盘?
  • 光速晋级!2025年多哈世乒赛孙颖莎4比0战胜对手
  • 林诗栋/蒯曼混双取胜,国乒赢得多哈世乒赛开门红
  • 舞者王佳俊谈“与AI共舞”:像多了一个舞伴,要考虑它的“感受”
  • 特朗普公开“怼”库克:苹果不应在印度生产手机