python注册登录+mysql_Python学习笔记_05:使用Flask+MySQL实现用户登陆注册以及增删查改操作...

前言:本文代码参考自两篇英文博客,具体来源点击文末代码链接中文档说明。 (PS:代码运行Python版本为2.7.14)

运行效果:

首页:

注册页面:

登陆界面:

管理员登陆后界面:

添加、删除、修改和查询员工所在部门信息界面(角色和员工界面类似):

附学习过程中参考资料:

下面附加一篇博客,有关Flask登陆功能中使用Flask-Login库的具体讲解,通过这篇文章,能够加深自己对于Flask实现登陆功能的具体调用过程以及相关代码原理。

文章中最后源码:

# encoding: utf-8

from flask import Flask, Blueprint

from flask_login import (LoginManager, login_required, login_user,logout_user, UserMixin)

app = Flask(__name__)

# user models

class User(UserMixin):

def is_authenticated(self):

return True

def is_actice(self):

return True

def is_anonymous(self):

return False

def get_id(self):

return ""

# flask-login

app.secret_key = 's3cr3t'

login_manager = LoginManager()

login_manager.session_protection = 'strong'

login_manager.login_view = 'auth.login'

login_manager.init_app(app)

@login_manager.user_loader

def load_user(user_id):

user = User()

return user

auth = Blueprint('auth', __name__)

@auth.route('/login', methods=['GET', 'POST'])

def login():

user = User()

login_user(user)

return "login page"

@auth.route('/logout', methods=['GET', 'POST'])

@login_required

def logout():

logout_user()

return "logout page"

# test method

@app.route('/test')

@login_required

def test():

return "yes , you are allowed"

app.register_blueprint(auth, url_prefix='/auth')

app.run(debug=True)

在浏览器中输入如下url,查看相关结果:

http://localhost:5000/test

http://localhost:5000/auth/login

http://localhost:5000/auth/logout

PHP与MYSQL结合操作——文章发布系统小项目(实现基本增删查改操作)

php和mysql在一起几十年了,也是一对老夫老妻了,最近正在对他们的爱情故事进行探讨,并做了一个很简单的小东西——文章发布系统,目的是为了实现mysql对文章的基本增删查改操作 前台展示系统有:文章 ...

Java连接MySQL数据库及简单的增删查改操作

主要摘自 https://www.cnblogs.com/town123/p/8336244.html https://www.runoob.com/java/java-mysql-connect.h ...

mysql数据库技术1——基本的增删查改的sql语句

1.数据库语言的分类 DDL:数据库定义语言 data Definition language 用于创建.修改.和删除数据库内的数据结构,如: 1:创建和删除数据库(CREATE DATABASE | ...

Python学习笔记 使用数据库SQlite Mysql

SQLite是一种嵌入式数据库,它的数据库就是一个文件.由于SQLite本身是C写的,而且体积很小,所以,经常被集成到各种应用当中, 甚至在IOS和Android的APP中都可以集成 Python就内 ...

python学习笔记十三:Flask demo

一.Flask简介 Flask 是一个 Python 实现的 Web 开发微框架.官网:http://flask.pocoo.org/ 二.Demo 1.代码结构 . ├── blog.py ├── ...

Python学习笔记整理总结【MySQL】

一. 数据库介绍 1.什么是数据库?数据库(Database)是按照数据结构来组织.存储和管理数据的仓库.每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据.我们也可以将 ...

Python学习笔记10-Python MysqlHelper ,MySql 辅助类

自己写了一个MySql辅助类,有需要的拿走: #--encoding:utf-8-- # import MySQLdb class MySQLHelper: myVersion=0.1 def __i ...

python中关于list列表的增删查改操作

python中list的操#python创建列表的时候,会以堆栈的形式存放数据,从右向左往堆栈中存放数据 movies=["The holy Grail","The li ...

mysql与PHP建立连接实现增删查改

mysql与PHP连接的查询写法: <?php //1.建立与数据库的连接 //类似于宽字符集问题,mysqli是额外的扩展 //需要找到配置文件去开启扩展 //如果需要在调用函数 之前忽略错误 ...

随机推荐

ural 1075&period; Thread in a Space

1075. Thread in a Space Time limit: 1.0 secondMemory limit: 64 MB There are three points in a 3-dime ...

dubbo 转

http://blog.csdn.net/zhiguozhu/article/details/50517513 背景 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式 ...

javascript 获取 class 样式 重新赋值class样式 为div等系列标签内更改内容

name = document.getElementById(project_not_through_id).className;                     // 获取目标id的 cla ...

Oracle索引&lpar;B&ast;tree与Bitmap&rpar;的学习总结

在Oracle中,索引基本分为以下几种:B*Tree索引,反向索引,降序索引,位图索引,函数索引,interMedia全文索引等,其中最常用的是B*Tree索引和Bitmap索引.(1).与索引相关视 ...

HDOJ 2016 数据的交换输出

Problem Description 输入n(n<100)个数,找出其中最小的数,将它与最前面的数交换后输出这些数. Input 输入数据有多组,每组占一行,每行的开始是一个整数n,表示这个测 ...

javascript笔记6之函数

/* function box() { //函数的声明 alert('我只有被调用才可以执行!'); //函数本身没有运行功能 } //必须调用才可以执行 box(); //调用 function b ...

hdu 5014 思维题&sol;推理

http://acm.hdu.edu.cn/showproblem.php?pid=5014 从小数開始模拟找方法规律,然后推广,尤其敢猜敢尝试,错了一种思路继续猜-----这是一种非常重要的方法啊 ...

dlopen函数详解

Linux提供了一套API来动态装载库.下面列出了这些API: - dlopen,打开一个库,并为使用该库做些准备.- dlsym,在打开的库中查找符号的值.- dlclose,关闭库.- dlerr ...

SQL数据库修复&sol;数据库置疑修复

SQL数据库修复的三大核心技术: 1.磁盘阵列分析重组技术: 2.数据库恢复与修复技术: 3.SCSI盘物理故障开盘技术. 至今已经成功恢复数百台服务器的SQL数据库,用户覆盖全国. 导致SQL数据库 ...

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python使用FlaskMySQL可以很方便地实现用户注册、登录和登出功能。 首先,我们需要安装Flask和PyMySQL库,并导入所需的模块。 ```python from flask import Flask, render_template, request, redirect, session import pymysql ``` 接下来,我们需要创建一个Flask应用程序,并配置数据库连接。 ```python app = Flask(__name__) app.secret_key = 'your_secret_key' # 设置session密钥 conn = pymysql.connect( host='your_host', user='your_username', password='your_password', db='your_database' ) ``` 然后,我们可以定义一些路由来处理用户注册和登录的请求。 ```python @app.route('/register', methods=['GET', 'POST']) def register(): if request.method == 'POST': username = request.form['username'] password = request.form['password'] # 在这里将用户信息插入到数据库中 cursor = conn.cursor() sql = "INSERT INTO users (username, password) VALUES (%s, %s)" cursor.execute(sql, (username, password)) conn.commit() cursor.close() return redirect('/login') return render_template('register.html') @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': username = request.form['username'] password = request.form['password'] # 在这里从数据库中验证用户信息 cursor = conn.cursor() sql = "SELECT * FROM users WHERE username = %s AND password = %s" cursor.execute(sql, (username, password)) user = cursor.fetchone() cursor.close() if user: session['username'] = username return redirect('/') else: return render_template('login.html', message='用户名或密码错误') return render_template('login.html') @app.route('/logout') def logout(): session.pop('username', None) return redirect('/login') ``` 最后,我们可以定义一个主页路由来展示当前登录状态。 ```python @app.route('/') def home(): if 'username' in session: return '当前用户:' + session['username'] + '<br><a href="/logout">登出</a>' else: return '未登录<br><a href="/login">登录</a>' ``` 你还需要创建一个注册页面和登录页面的模板文件。 ```html <!-- register.html --> <form method="POST" action="/register"> <input type="text" name="username" placeholder="用户名"><br> <input type="password" name="password" placeholder="密码"><br> <button type="submit">注册</button> </form> ``` ```html <!-- login.html --> <form method="POST" action="/login"> <input type="text" name="username" placeholder="用户名"><br> <input type="password" name="password" placeholder="密码"><br> <button type="submit">登录</button> </form> <p>{{ message }}</p> ``` 最后,我们需要运行Flask应用程序。 ```python if __name__ == '__main__': app.run() ``` 现在,你可以通过访问http://localhost:5000/register来注册用户,并访问http://localhost:5000/login来登录。登出功能可以通过访问http://localhost:5000/logout来实现。主页会展示当前登录状态。 以上就是使用PythonFlaskMySQL实现用户注册、登录和登出的简单示例。希望能帮到你!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值