前言:

本例使用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. 设备像素,CSS像素,设备独立像素

    1.概念 设备像素(device pixel)简写DP 设备像素又称 **物理像素** ,是设备能控制显示的最小单位,我们可以把它看做显示器上的一个点.我们常说的 1920x1080像素分辨率就是用的 ...

  2. WebGL小姐姐教我学画画之起手式

    初次接触WebGL,如有错误之处欢迎留言,共同学习进步. v WebGL的自画像 我,WebGL,全名Web Graphics Library,是为了让死宅程序猿们(摊手)能在浏览器上为所欲为的画女朋 ...

  3. Redis分布式实现原理

    一.使用 1.pom.xml导入依赖 <dependency> <groupId>org.springframework.boot</groupId> <ar ...

  4. vue 跨域配置代理 get/post 请求

    1.第一步要有 axios 插件 : npm i axios 首先要在自己的项目手动添加一个文件 vue.config.js 个人理解的为 这是axios 封装的跨域文件. 2.vue.config. ...

  5. 开始项目之前整理Xmind

    今天为将要做的项目整理了一份Xmind文档,每个页面,模块,功能都记了下来.带我的老师说过于详细了,但我还是新手,也不懂哪里改精简那里不该. 总结:整理Xmind文档还是很有必要的,之前这个项目我大致 ...

  6. Python爬虫__微博某个话题的内容数据

    1 # -*- coding: utf-8 -*- 2 # @Time : 2020/8/18 15:39 3 # @Author : Chunfang 4 # @Email : 3470959534 ...

  7. 企业级 Web 开发的挑战

    本文翻译自土牛Halil ibrahim Kalkan的<Mastering ABP Framework>,是系列翻译的起头,适合ABP开发人员或者想对ABP框架进行深入演进的准架构师. ...

  8. JavaWeb之如何把请求数据转成实体类

    JavaWeb之如何把请求数据转成实体类 自己写个工具类加入下面两个静态方法 自定一个注解类DateTimeFormatting 调用方式User user = util.ObjectFromMap( ...

  9. SoftPool:基于Softmax加权的池化操作 | 2021新文

    SoftPool使用softmax进行加权池化,能够保持特征的表达性并且是可微操作.从性能和准确率来看,SoftPool是目前的常规池化方法的一个不错的替代品   来源:晓飞的算法工程笔记 公众号 论 ...

  10. Nacos在企业生产中如何使用集群环境?

    点赞再看,养成习惯,微信搜索[牧小农]关注我获取更多资讯,风里雨里,小农等你,很高兴能够成为你的朋友. 项目源码地址:公众号回复 nacos,即可免费获取源码 前言 由于在公司,注册中心和配置中心都是 ...