前言:

本例使用Flask框架完成登录和注册操作,包括前端(index.html,regist.html)和后端(app.py)两部分,前端页面不过多介绍,直接进入后端部分:

逻辑思路:

登录部分:运行程序默认进入登录界面,输入账号和密码点击登录,系统进入”获取登录请求参数及处理“阶段(@app.route('/login')),验证账号密码正确后跳转到目标界面。

注册部分:运行程序输入注册部分的路由进入注册界面,输入账号、密码和确认密码,系统进入”获取注册请求及处理“阶段(@app.route('/registuser')),判断两次输入密码是否一致,一致则跳转到登录界面,否则弹出警告框提示用户重新输入。

主要步骤:

①导入需要的扩展包

#导入数据库模块
import pymysql from flask import Flask
from flask import render_template #导入前台请求的request模块
from flask import request
import traceback
#导入弹出警告框模块
import win32api,win32con

②定义登录界面路由

#默认登录页面
@app.route('/')
def login():
return render_template('login.html')

③定义注册界面路由

#访问注册页面
@app.route('/regist')
def regist():
return render_template('regist.html')

④获取登录请求参数及处理

@app.route('/login')
def getLoginRequest():
# 查询用户名及密码是否匹配及存在
# 连接数据库,此前在数据库中创建数据库TESTDB
db = pymysql.connect(host="localhost", user="root", password="417020", database="flask",charset="utf8")
# 使用cursor()方法获取操作游标
cursor = db.cursor()
# SQL 查询语句
sql = "select * from user where user=" + request.args.get('user') + " and password=" + request.args.get(
'password') + ""
try:
# 执行sql语句
cursor.execute(sql)
results = cursor.fetchall()
print(len(results))
if len(results) == 1:
return '登录成功' #返回需要跳转的页面或需要显示的字符串
else:
return '用户名或密码不正确'
# 提交到数据库执行
db.commit()
except:
# 如果发生错误则回滚
traceback.print_exc()
db.rollback()
# 关闭数据库连接
db.close()

⑤获取注册请求及处理

@app.route('/registuser')
def getRigistRequest():
#把用户名和密码注册到数据库中 #连接数据库,此前在数据库中创建数据库flask
db = pymysql.connect(host="localhost", user="root", password="417020", database="flask",charset="utf8")
#使用cursor()方法获取操作游标
cursor = db.cursor()
#获取输入框内容
username=request.args.get('user')
password=request.args.get('password')
password2=request.args.get('password2')
print(password)
print(password2)
#判断两次输入密码是否一致,一致则跳转到登录界面,不一致则弹出警告,要求用户重新输入
if password==password2:
# SQL 插入语句
sql = "INSERT INTO user(user, password) VALUES ("+username+", "+password+")"
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
#注册成功之后跳转到登录页面
return render_template('login.html')
except:
#抛出错误信息
traceback.print_exc()
# 如果发生错误则回滚
db.rollback()
return '注册失败'
# 关闭数据库连接
db.close()
else:
win32api.MessageBox(0,"两次输入密码不一致,请重新输入!","提醒",win32con.MB_ICONWARNING)
return render_template('regist.html')

完整代码:

#导入数据库模块
import pymysql from flask import Flask
from flask import render_template #导入前台请求的request模块
from flask import request
import traceback
#导入弹出警告框模块
import win32api,win32con #创建Flask应用实例
app = Flask(__name__) #默认登录页面
@app.route('/')
def login():
return render_template('login.html') #访问注册页面
@app.route('/regist')
def regist():
return render_template('regist.html') #获取注册请求及处理
@app.route('/registuser')
def getRigistRequest():
#把用户名和密码注册到数据库中 #连接数据库,此前在数据库中创建数据库flask
db = pymysql.connect(host="localhost", user="root", password="417020", database="flask",charset="utf8")
#使用cursor()方法获取操作游标
cursor = db.cursor()
#获取输入框内容
username=request.args.get('user')
password=request.args.get('password')
password2=request.args.get('password2')
print(password)
print(password2)
#判断两次输入密码是否一致,一致则跳转到登录界面,不一致则弹出警告,要求用户重新输入
if password==password2:
# SQL 插入语句
sql = "INSERT INTO user(user, password) VALUES ("+username+", "+password+")"
try:
# 执行sql语句
cursor.execute(sql)
# 提交到数据库执行
db.commit()
#注册成功之后跳转到登录页面
return render_template('login.html')
except:
#抛出错误信息
traceback.print_exc()
# 如果发生错误则回滚
db.rollback()
return '注册失败'
# 关闭数据库连接
db.close()
else:
win32api.MessageBox(0,"两次输入密码不一致,请重新输入!","提醒",win32con.MB_ICONWARNING)
return render_template('regist.html') # 获取登录参数及处理
@app.route('/login')
def getLoginRequest():
# 查询用户名及密码是否匹配及存在
# 连接数据库,此前在数据库中创建数据库TESTDB
db = pymysql.connect(host="localhost", user="root", password="417020", database="flask",charset="utf8")
# 使用cursor()方法获取操作游标
cursor = db.cursor()
# SQL 查询语句
sql = "select * from user where user=" + request.args.get('user') + " and password=" + request.args.get(
'password') + ""
try:
# 执行sql语句
cursor.execute(sql)
results = cursor.fetchall()
print(len(results))
if len(results) == 1:
return '登录成功' #返回需要跳转的页面或需要显示的字符串
else:
return '用户名或密码不正确'
# 提交到数据库执行
db.commit()
except:
# 如果发生错误则回滚
traceback.print_exc()
db.rollback()
# 关闭数据库连接
db.close() # 使用__name__ == '__main__'是 Python 的惯用法,确保直接执行此脚本时才
# 启动服务器,若其他程序调用该脚本可能父级程序会启动不同的服务器
if __name__ == '__main__':
app.run(debug=True)

Flask框架实现登录注册功能(mysql数据库)的更多相关文章

  1. flask 开发用户登录注册功能

    flask 开发用户登录注册功能 flask开发过程议案需要四个模块:html页面模板.form表单.db数据库操作.app视图函数 1.主程序 # app.py # Auther: hhh5460 ...

  2. Java Spring+Mysql+Mybatis 实现用户登录注册功能

    前言: 最近在学习Java的编程,前辈让我写一个包含数据库和前端的用户登录功能,通过看博客等我先是写了一个最基础的servlet+jsp,再到后来开始用maven进行编程,最终的完成版是一个 Spri ...

  3. vue koa2 mongodb 从零开始做个人博客(一) 登录注册功能前端部分

    0.效果演示 插入视频插不进来,就很烦.可以出门右拐去优酷看下(点我!). 1.准备工作 1.1前端框架 前端使用了基于vue.js的nuxt.js.为什么使用nuxt.js? 首先我做的是博客的项目 ...

  4. Node.js实现登录注册功能

    使用Node.js + Navicat for mysql实现的登录注册功能 数据库中存在有”user_id,user_name,password,user_img,user_number“字段,其中 ...

  5. JAVAEE_Servlet_20_登录注册功能

    实现登录注册功能 注册功能 import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import j ...

  6. SSM 实现登录注册功能

    1.上一篇SSM框架搭建好了之后就要开始写功能了,现在来写一个简单的登录注册功能 这几个包是自己手动创建的,然后往里面写代码 2.代码详情 package com.maike.controller; ...

  7. Linux - mysql 异常:登录不上mysql数据库

    问题描述 重启虚拟机之后,用命令 mysql -u root -p 登录不上 mysql 数据库,页面显示: 但是,用命令 service mysqld status 可以查看状态 解决方案 1.查看 ...

  8. 一个关于vue+mysql+express的全栈项目(三)------ 登录注册功能的实现(已经密码安全的设计)

    本系列文章,主要是一个前端的视角来实现一些后端的功能,所以不会讲太多的前端东西,主要是分享做这个项目学到的一些东西,,,,, 好了闲话不多说,我们开始搭建后端服务,这里我们采用node的express ...

  9. django框架--登录注册功能(ajax)

    注册 实现一个注册功能 编写 html 内容 input 标签 csrf_token ajax 路由 视图: 提供页面 负责处理业务,返回响应 接收到   post   请求传递的参数 写库 返回   ...

随机推荐

  1. 搞半天,全国34个省份包含湾湾\香港\澳门的高德poi兴趣点23类数据终于爬完事了

    1.技术架构: python+阿里云数据库mongodb5.0+高德地图rest api 2.成本: 阿里云数据库mongodb5.0一个月话费1k多 2.遇到的问题 1)两个阿里云账号下 mongo ...

  2. Flutter入门教程(四)第一个flutter项目解析

    一.创建一个Flutter工程 1.1 命令行创建 首先我们找一个空目录用来专门存放flutter项目,然后在路径中直接输入cmd: 使用 flutter create <projectname ...

  3. 在vue中创建多个ueditor实例

    简介 在vue中创建多个ueditor实例,我使用neditor,其实就是把ueditor样式美化了下,其他和ueditor几乎一样 截图 源码地址 https://github.com/oblivi ...

  4. 前端网络安全——Cookies

    一.Cookies特性 1.前端数据存储 2.后端通过http头设置 3.请求时通过http头传给后端 4.前端可读写 5.遵守同源策略 二.Cookies内容 1.域名 2.有效期,删除cookie ...

  5. Anaconda安装tensorflow和keras(gpu版,超详细)

    本人配置:window10+GTX 1650+tensorflow-gpu 1.14+keras-gpu 2.2.5+python 3.6,亲测可行 一.Anaconda安装 直接到清华镜像网站下载( ...

  6. RStudio中文乱码

    解决办法一: 1.设置RStudio文本显示的默认编码:RStudio菜单栏的Tools -> Global Options 2.code-->saving-->default te ...

  7. FastAPI(七十四)实战开发《在线课程学习系统》接口开发-- 删除留言

    之前文章FastAPI(七十三)实战开发<在线课程学习系统>接口开发-- 回复留言,那么我们这次分享删除留言接口的开发 可以对留言进行删除,这里的删除,我们使用的是逻辑的删除,不是物理删除 ...

  8. python入门-开始

    1.为啥要学Python? 各种语言的优劣势对比视频版:https://www.bilibili.com/video/BV1y3411r7pX/?spm_id_from=autoNext 各种语言的优 ...

  9. Ubuntu中hyperledger-fabric2.3.0环境搭建

    系统环境 hyperledger-fabric在Ubuntu安装过程,fabric版本为2.3.0 首先安装相关软件 1.安装docker 直接参考下面这篇文档安装好docker-ce即可 Ubunt ...

  10. 在 Docker 上快速运行 Apache Airflow 2.2.4

    Docker 安装 Apache Airflow 参考资料 Running Airflow in Docker 安装依赖 Docker Engine Docker Composite 快速运行 Apa ...