Flask 用户注册功能实现

创建 Flask 用户注册功能

安装 Flask 和相关扩展

确保已安装 Flask 和 Flask-WTF、Flask-SQLAlchemy 等扩展。可以通过以下命令安装:

bash 复制代码
pip install flask flask-wtf flask-sqlalchemy
初始化 Flask 应用

创建一个名为 app.py 的文件,初始化 Flask 应用并配置数据库:

python 复制代码
from flask import Flask, render_template, redirect, url_for, flash
from flask_sqlalchemy import SQLAlchemy
from flask_wtf import FlaskForm
from wtforms import StringField, PasswordField, SubmitField
from wtforms.validators import DataRequired, Email, EqualTo

app = Flask(__name__)
app.config['SECRET_KEY'] = 'your-secret-key'
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///site.db'
db = SQLAlchemy(app)
创建用户模型

定义一个用户模型,用于存储用户信息:

python 复制代码
class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(20), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)
    password = db.Column(db.String(60), nullable=False)

    def __repr__(self):
        return f"User('{self.username}', '{self.email}')"
创建注册表单

使用 Flask-WTF 创建一个注册表单:

python 复制代码
class RegistrationForm(FlaskForm):
    username = StringField('Username', validators=[DataRequired()])
    email = StringField('Email', validators=[DataRequired(), Email()])
    password = PasswordField('Password', validators=[DataRequired()])
    confirm_password = PasswordField('Confirm Password', validators=[DataRequired(), EqualTo('password')])
    submit = SubmitField('Sign Up')
实现注册路由

创建一个路由处理用户注册请求:

python 复制代码
@app.route('/register', methods=['GET', 'POST'])
def register():
    form = RegistrationForm()
    if form.validate_on_submit():
        user = User(username=form.username.data, email=form.email.data, password=form.password.data)
        db.session.add(user)
        db.session.commit()
        flash('Your account has been created! You can now log in.', 'success')
        return redirect(url_for('login'))
    return render_template('register.html', form=form)
创建注册模板

创建一个名为 register.html 的模板文件,用于显示注册表单:

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>Register</title>
</head>
<body>
    <h1>Register</h1>
    <form method="POST" action="">
        {{ form.hidden_tag() }}
        <div>
            {{ form.username.label }}<br>
            {{ form.username(size=32) }}<br>
            {% for error in form.username.errors %}
                <span style="color: red;">[{{ error }}]</span><br>
            {% endfor %}
        </div>
        <div>
            {{ form.email.label }}<br>
            {{ form.email(size=32) }}<br>
            {% for error in form.email.errors %}
                <span style="color: red;">[{{ error }}]</span><br>
            {% endfor %}
        </div>
        <div>
            {{ form.password.label }}<br>
            {{ form.password(size=32) }}<br>
            {% for error in form.password.errors %}
                <span style="color: red;">[{{ error }}]</span><br>
            {% endfor %}
        </div>
        <div>
            {{ form.confirm_password.label }}<br>
            {{ form.confirm_password(size=32) }}<br>
            {% for error in form.confirm_password.errors %}
                <span style="color: red;">[{{ error }}]</span><br>
            {% endfor %}
        </div>
        <div>
            {{ form.submit() }}
        </div>
    </form>
</body>
</html>
运行应用

app.py 文件中添加以下代码以运行应用:

python 复制代码
if __name__ == '__main__':
    db.create_all()
    app.run(debug=True)

启动应用后,访问 http://localhost:5000/register 即可看到注册页面。填写表单并提交后,用户信息将保存到数据库中。

相关推荐
哈里谢顿3 小时前
Django 应用 OOM(Out of Memory)故障的定位思路和排查方法
python·django
甄心爱学习3 小时前
【python】获取所有长度为 k 的二进制字符串
python·算法
tuotali20264 小时前
氢气压缩机技术规范亲测案例分享
人工智能·python
嫂子的姐夫4 小时前
030-扣代码:湖北图书馆登录
爬虫·python·逆向
a1117765 小时前
EasyVtuber(或其衍生/增强版本)的虚拟主播(Vtuber)面部动画生成与直播解决方案
python·虚拟主播
lintax5 小时前
计算pi值-积分法
python·算法·计算π·积分法
小凯123455 小时前
pytest框架-详解(学习pytest框架这一篇就够了)
python·学习·pytest
逻极5 小时前
pytest 入门指南:Python 测试框架从零到一(2025 实战版)
开发语言·python·pytest