Flask-05-——(注册功能的实现,六、1将用户提交的注册数据保存在数据库 六、2 发送AJAX请求 六、3验证码的获取六、4验证码倒计时)

六、注册功能的实现

六、1将用户提交的注册数据保存在数据库

1.创建一个ORM模型,并且在数据库创建该表
models.py

from exts import db
from datetime import datetime

class EmailCaptchaModel(db.Model):
    __tablename__ = "email_captcha"
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    email = db.Column(db.String(100), nullable=False, unique=True)
    captcha = db.Column(db.String(10), nullable=False)
    create_time = db.Column(db.DateTime, default=datetime.now)


class UserModel(db.Model):
    __tablename__ = "user"
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    username = db.Column(db.String(200), nullable=False, unique=True)
    email = db.Column(db.String(100), nullable=False, unique=True)
    password = db.Column(db.String(200), nullable=False)
    join_time = db.Column(db.DateTime, default=datetime.now)

在这里插入图片描述

2.完善前端代码,比如各个输入框的完善,加入name可以进行定位。加入用户名
register.html

{% extends "base.html" %}

{% block title %}注册{% endblock %}

{% block head %}

{% endblock %}

{% block body %}
  <div class="row mt-4">
    <div class="col"></div>
    <div class="col">
          <form method="POST" action="{{ url_for('user.register') }}">
        <div class="form-group">
          <label for="exampleInputEmail1">邮箱</label>
          <input type="email" class="form-control" id="exampleInputEmail1" aria-describedby="emailHelp" name="email">
          <small id="emailHelp" class="form-text text-muted">We'll never share your email with anyone else</small>
        </div>

        <div class="form-group">
          <label for="exampleInputEmail1">验证码</label>
          <div class="input-group">
            <input type="text" class="form-control" name="captcha">
            <div class="input-group-append">
              <button class="btn btn-outline-secondary" type="button" id="captcha-btn">获取验证码</button>
            </div>
          </div>
        </div>

        <div class="form-group">
          <label for="exampleInputEmail1">用户名</label>
          <input type="text" class="form-control"  name="username">
        </div>


        <div class="form-group">
          <label for="exampleInputPassword1">密码</label>
          <input type="password" class="form-control" id="exampleInputPassword1" name="password">
        </div>

        <div class="form-group">
          <label for="exampleInputPassword1">确认密码</label>
          <input type="password" class="form-control" name="password_confirm">
        </div>
        <button type="submit" class="btn btn-primary btn-block">立即注册</button>
      </form>
    </div>
    <div class="col"></div>
  </div>
{% endblock %}

3.新建forms.py表单,用于验证验证码和邮箱,需要在user.py导入

import wtforms
from wtforms.validators import length,email,EqualTo,InputRequired
from models import EmailCaptchaModel,UserModel


class LoginForm(wtforms.Form):
    email = wtforms.StringField(validators=[email()])
    password = wtforms.StringField(validators=[length(min=6,max=20)])


class RegisterForm(wtforms.Form):
    username = wtforms.StringField(validators=[length(min=3,max=20)])
    email = wtforms.StringField(validators=[email()])
    captcha = wtforms.StringField(validators=[length(min=4, max=4)])
    password = wtforms.StringField(validators=[length(min=6,max=20)])
    password_confirm = wtforms.StringField(validators=[EqualTo("password")])

    def validate_captcha(self,field):
        captcha = field.data
        email = self.email.data
        captcha_model = EmailCaptchaModel.query.filter_by(email=email).first()
        if not captcha_model or captcha_model.captcha.lower() != captcha.lower():
            raise wtforms.ValidationError("邮箱验证码错误!")

    def validate_email(self,field):
        email = field.data
        user_model = UserModel.query.filter_by(email=email).first()
        if user_model:
            raise wtforms.ValidationError("邮箱已经存在!")

models.py

from exts import db
from datetime import datetime


class EmailCaptchaModel(db.Model):
    __tablename__ = "email_captcha"
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    email = db.Column(db.String(100), nullable=False, unique=True)
    captcha = db.Column(db.String(10), nullable=False)
    create_time = db.Column(db.DateTime, default=datetime.now)


class UserModel(db.Model):
    __tablename__ = "user"
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    username = db.Column(db.String(200), nullable=False, unique=True)
    email = db.Column(db.String(100), nullable=False, unique=True)
    password = db.Column(db.String(200), nullable=False)
    join_time = db.Column(db.DateTime, default=datetime.now)

user.py

import random
import string

from flask import Blueprint, render_template, request, redirect, url_for

from blueprints.forms import RegisterForm
from exts import mail, db
from flask_mail import Message
from models import EmailCaptchaModel, UserModel
from datetime import datetime
from werkzeug.security import generate_password_hash,check_password_hash #加密解密

bp = Blueprint("user", __name__, url_prefix="/user")


@bp.route("/login")
def login():
    return render_template("login.html")


@bp.route("/register",methods=['GET','POST'])
def register():
    if request.method == 'GET':
        return render_template("register.html")
    else:
        form = RegisterForm(request.form)
        if form.validate():
            email = form.email.data
            username = form.username.data
            password = form.password.data
            #md5利用hash加密
            hash_password=generate_password_hash(password)
            user = UserModel(email=email, username=username, password=hash_password)
            db.session.add(user)
            db.session.commit()
            return redirect(url_for("user.login"))
        else:
            return redirect(url_for("user.register"))



@bp.route("/captcha",methods=['POST'])
def get_captcha():
    email = request.args.get("email")
    letter = string.ascii_letters + string.digits
    captcha = "".join(random.sample(letter, 4))
    if email:
        message = Message(
            subject='邮箱测试',
            recipients=['需要注册的邮箱'],
            body=f"您的注册验证码是:{captcha},请不要告诉任何人哦!"
        )
        mail.send(message)
        #判断邮箱是否存在,诺存在,更新数据库中得验证码
        captcha_model = EmailCaptchaModel.query.filter_by(email=email).first()
        if captcha_model:
            captcha_model.captcha = captcha
            captcha_model.create_time = datetime.now()
            db.session.commit()
        else:
            captcha_model = EmailCaptchaModel(email=email, captcha=captcha)
            db.session.add(captcha_model)
            db.session.commit()
        return "success"
    else:
        return "没有传递邮箱"

在这里插入图片描述

六、2 发送AJAX请求

实现功能:给服务器发送获取验证码的请求,前端提示验证码发送成功,添加验证码倒计时
需要用到js,整个网页全部加载完成再绑定点击事件

获取验证码
用到的所有文件:
在这里插入图片描述
其中jquery.3.6.min.js可以在jquery.3.6.min.js下载

通过js绑定点击事件
register.js

function bindCaptchaBtnClick() {
    $("#captcha-btn").on("click", function (event) {
        var $this = $(this);
        var email = $("input[name='email']").val();
        if (!email) {
            alert("请先输入邮箱!");
            return;
        }
        // 通过js发送网络请求:ajax。Async JavaScript And XML(JSON)
        // Jinja2
        $.ajax({
            url: "/user/captcha",
            method: "POST",
            data: {
                "email": email
            },
            success: function (res) {
                var code = res['code'];
                if (code == 200) {
                    // 取消点击事件
                    $this.off("click");
                    // 开始倒计时
                    var countDown = 60;
                    var timer = setInterval(function () {
                        countDown -= 1;
                        if (countDown > 0) {
                            $this.text(countDown + "秒后重新发送");
                        } else {
                            $this.text("获取验证码");
                            // 重新执行下这个函数,重新绑定点击事件
                            bindCaptchaBtnClick();
                            // 如果不需要倒计时了,那么就要记得清除倒计时,否则会一直执行下去
                            clearInterval(timer);
                        }
                    }, 1000);
                    alert("验证码发送成功!");
                } else {
                    alert(res['message']);
                }
            }
        })
    });
}


// 等网页文档所有元素都加载完成后再执行
$(function () {
    bindCaptchaBtnClick();
});

user.py

import random
import string

from flask import Blueprint, render_template, request, redirect, url_for, jsonify

from blueprints.forms import RegisterForm
from exts import mail, db
from flask_mail import Message
from models import EmailCaptchaModel, UserModel
from datetime import datetime
from werkzeug.security import generate_password_hash, check_password_hash  # 加密解密

bp = Blueprint("user", __name__, url_prefix="/user")


@bp.route("/login")
def login():
    return render_template("login.html")


@bp.route("/register", methods=['GET', 'POST'])
def register():
    if request.method == 'GET':
        return render_template("register.html")
    else:
        form = RegisterForm(request.form)
        if form.validate():
            email = form.email.data
            username = form.username.data
            password = form.password.data
            # md5利用hash加密
            hash_password = generate_password_hash(password)
            user = UserModel(email=email, username=username, password=hash_password)
            db.session.add(user)
            db.session.commit()
            return redirect(url_for("user.login"))
        else:
            return redirect(url_for("user.register"))


@bp.route("/captcha", methods=['POST'])
def get_captcha():
    # GET,POST
    email = request.form.get("email")
    letters = string.ascii_letters + string.digits
    captcha = "".join(random.sample(letters, 4))
    if email:
        message = Message(
            subject="邮箱测试",
            recipients=[email],
            body=f"【知了问答】您的注册验证码是:{captcha},请不要告诉任何人哦!"
        )
        mail.send(message)
        captcha_model = EmailCaptchaModel.query.filter_by(email=email).first()
        if captcha_model:
            captcha_model.captcha = captcha
            captcha_model.create_time = datetime.now()
            db.session.commit()
        else:
            captcha_model = EmailCaptchaModel(email=email, captcha=captcha)
            db.session.add(captcha_model)
            db.session.commit()
        print("captcha:", captcha)
        # code: 200,成功的、正常的请求
        return jsonify({"code": 200})
    else:
        # code:400,客户端错误
        return jsonify({"code": 400, "message": "请先传递邮箱!"})

在这里插入图片描述
点击确定之后开始倒计时。
在这里插入图片描述

在这里插入图片描述
在网站中输入注册之后,数据库收到用户名,密码,注册时间,至此注册功能完成。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
下面是一个使用 Flask 实现用户登录注册界面,并将用户数据存储在 SQLite 数据库中的示例代码: 1. 安装需要的依赖 ``` pip install Flask pip install Flask-WTF pip install Flask_SQLAlchemy pip install Werkzeug ``` 2. 创建 Flask 应用并配置 ```python from flask import Flask, render_template, redirect, url_for, flash from flask_wtf import FlaskForm from wtforms import StringField, PasswordField, SubmitField from wtforms.validators import InputRequired, Length, EqualTo from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) app.config['SECRET_KEY'] = 'secret_key' app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///users.db' db = SQLAlchemy(app) ``` 3. 创建用户模型 ```python class User(db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(50), unique=True) password = db.Column(db.String(100)) def __repr__(self): return f'<User {self.username}>' ``` 4. 创建表单类 ```python class RegistrationForm(FlaskForm): username = StringField('Username', validators=[InputRequired(), Length(min=4, max=50)]) password = PasswordField('Password', validators=[InputRequired(), Length(min=6, max=100)]) confirm_password = PasswordField('Confirm Password', validators=[InputRequired(), EqualTo('password')]) submit = SubmitField('Register') class LoginForm(FlaskForm): username = StringField('Username', validators=[InputRequired(), Length(min=4, max=50)]) password = PasswordField('Password', validators=[InputRequired(), Length(min=6, max=100)]) submit = SubmitField('Login') ``` 5. 创建路由和视图函数 ```python @app.route('/') def index(): return render_template('index.html') @app.route('/register', methods=['GET', 'POST']) def register(): form = RegistrationForm() if form.validate_on_submit(): user = User(username=form.username.data, password=form.password.data) db.session.add(user) db.session.commit() flash('Registration successful', 'success') return redirect(url_for('login')) return render_template('register.html', form=form) @app.route('/login', methods=['GET', 'POST']) def login(): form = LoginForm() if form.validate_on_submit(): user = User.query.filter_by(username=form.username.data).first() if user and user.password == form.password.data: flash('Login successful', 'success') return redirect(url_for('index')) else: flash('Invalid username or password', 'error') return render_template('login.html', form=form) ``` 6. 创建模板文件 index.html: ```html <!DOCTYPE html> <html> <head> <title>Home - Flask App</title> </head> <body> <h1>Welcome to Flask App</h1> <p><a href="{{ url_for('login') }}">Login</a> or <a href="{{ url_for('register') }}">Register</a></p> </body> </html> ``` register.html: ```html <!DOCTYPE html> <html> <head> <title>Register - Flask App</title> </head> <body> <h1>Register</h1> <form method="POST" action="{{ url_for('register') }}"> {{ form.csrf_token }} {{ form.username.label }} {{ form.username }} {% for error in form.username.errors %} <span style="color: red;">[{{ error }}]</span> {% endfor %} <br><br> {{ form.password.label }} {{ form.password }} {% for error in form.password.errors %} <span style="color: red;">[{{ error }}]</span> {% endfor %} <br><br> {{ form.confirm_password.label }} {{ form.confirm_password }} {% for error in form.confirm_password.errors %} <span style="color: red;">[{{ error }}]</span> {% endfor %} <br><br> {{ form.submit }} </form> </body> </html> ``` login.html: ```html <!DOCTYPE html> <html> <head> <title>Login - Flask App</title> </head> <body> <h1>Login</h1> <form method="POST" action="{{ url_for('login') }}"> {{ form.csrf_token }} {{ form.username.label }} {{ form.username }} {% for error in form.username.errors %} <span style="color: red;">[{{ error }}]</span> {% endfor %} <br><br> {{ form.password.label }} {{ form.password }} {% for error in form.password.errors %} <span style="color: red;">[{{ error }}]</span> {% endfor %} <br><br> {{ form.submit }} </form> </body> </html> ``` 7. 运行 Flask 应用 ```python if __name__ == '__main__': app.run(debug=True) ``` 以上代码实现了一个简单的 Flask 应用,包括注册、登录等功能,并将用户数据存储在 SQLite 数据库中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值