import bdb
from flask import Blueprint, render_template, jsonify,redirect,url_for,session
from werkzeug.security import generate_password_hash, check_password_hash
from blueprints.forms import RegisterForm,LoginForm
from exts import mail, db
from flask_mail import Message
from flask import request
import string
import random
from models import EmailCaptchaModel
from models import UserModel
# 前缀
bp = Blueprint("auth", __name__, url_prefix="/auth")
@bp.route("/login",methods=['GET','POST'])
def login():
if request.method=='GET':
return render_template("login.html")
else:
form =LoginForm(request.form)
if form.validate():
email = form.email.data
password = form.password.data
user=UserModel.query.filter_by(email=email).first()
if not user:
print("邮箱在数据库不存在!")
return render_template("auth.login")
if check_password_hash(user.password,password):
# cookie:
# cookie中不适合存储大量信息,一般存储登录信息
# flask中的session,是经过加密后存储在cookie中的
session['user_id']=user.id
return redirect("/")
else:
print("密码错误")
return render_template("auth.login")
else:
print(form.errors)
return render_template("auth.login")
@bp.route("/register",methods=['GET','POST'])
def register():
# 验证用户提交验证码是否对应
# 表单验证flask_wft
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
user=UserModel(email=email,username=username,password=generate_password_hash(password))
db.session.add(user)
db.session.commit()
#return redirect("/auth/login")
return redirect(url_for("auth.login"))
else:
print(form.errors)
return redirect(url_for("auth.register"))
@bp.route("/logout")
def logout():
session.clear()
return redirect("/")
@bp.route("/captcha/email")
def get_email_captcha():
# /captcha/email/<email>
# /captcha/email?email=xx@qq.com
email = request.args.get("email")
source = string.digits * 4
captcha = random.sample(source, 4)
captcha = "".join(captcha)
message = Message(subject="验证码", recipients=[email], body=f"验证码为:{captcha}")
mail.send(message)
# memcached存在内存中/redis可同步到内盘
# 数据库存储(速度缓慢)
email_captcha = EmailCaptchaModel(email=email, captcha=captcha)
db.session.add(email_captcha)
db.session.commit()
# restful api
# code:200正常,400异常,错误message:”“,data{}
return jsonify({"code": 200, "message": "", "data": None})
@bp.route("/mail/test")
def mail_test():
message = Message(subject="邮箱测试", recipients=["2633087186@qq.com"], body="测试邮件")
mail.send(message)
return "邮件发送"
python-flask实现问答平台
需积分: 0 104 浏览量
更新于2023-12-28
2
收藏 124KB ZIP 举报
python——flask实现问答平台python——flask实现问答平台python——flask实现问答平台python——flask实现问答平台python——flask实现问答平台python——flask实现问答平台python——flask实现问答平台python——flask实现问答平台
kinggnu_
- 粉丝: 0
- 资源: 1
最新资源
- 基于Beego开发的问答系统详细文档+优秀项目+全部资料.zip
- 基于beego框架的接口在线文档管理系统详细文档+优秀项目+全部资料.zip
- 基于beego框架的cms系统详细文档+优秀项目+全部资料.zip
- 基于GF(Go Frame)的后台管理系统详细文档+优秀项目+全部资料.zip
- 基于Gin + Ant Design Pro的前后端分离管理系统的前后端模块详细文档+优秀项目+全部资料.zip
- 基于Excel VBA和Go语言的自动化考试系统详细文档+优秀项目+全部资料.zip
- 基于gin+websocket+mongodb实现 IM 即时聊天系统,基于WS连接的即时聊天,支持单聊,在线回复以及历史记录查询详细文档+优秀项目+全部资料.zip
- 基于Gin + Vue + Element UI & Arco Design & Ant Design 的前后端分离权限管理系统脚手架(包含了
- 基于gin+vue+element搭建的商城管理系统详细文档+优秀项目+全部资料.zip
- 基于Go + Vue开发的管理系统脚手架, 前后端分离, 仅包含项目开发的必需部分, 基于角色的访问控制(RBAC), 分包合理, 精简易于扩展。 后端Go包含
- 基于go micro + gin + kafka + etcd的分布式消息即时通信微服务系统详细文档+优秀项目+全部资料.zip
- 基于Go + Golang + Uniapp + Vue + ElementUi + Goframe框架的新零售社交电商系统(除了go商城系统外,还有java商
- 基于Go 标准库构建的博客系统、此项目非常适合作为 Go 新手的第一个上手项目详细文档+优秀项目+全部资料.zip
- 基于go,gin,JWT,权限管理系统详细文档+优秀项目+全部资料.zip
- 基于Go Web开发实战,基于Go语言,Beego框架开发的B2C模式的电商系统详细文档+优秀项目+全部资料.zip
- 基于go、gorm、gin、mysql及layui构建的人力资源管理系统。提供员工管理、考试管理、薪资考勤管理、权限管理及分公司分库数据隔离等功能详细文档+优秀项目+全部资料.zip