一个基于flask的web应用诞生 flask和mysql相连(4)


Posted in Python onApril 11, 2017

上一章实现了登录的部分功能,之所以说是部分功能,是因为用户名和密码写成固定值肯定是不可以的,一个整体的功能,至少需要注册,登录,密码修改等,这就需要提供一个把这些值存储到数据库的能力。

当前的主流数据库分为两种,即关系数据库和NoSql数据库,对于中小型的系统来说,两种数据库性能,易用性都相当,都是很好的选择。

基础配置

这里使用SQLAlchemy数据库框架的flask集成包,即flask-SQLAlchemy来进行数据库操作。

SQLAlchemy是一个非常好的框架,简化了数据库的操作,即提供了高层次的ORM,也提供了低层次的SQL功能,使用起来非常方便。

安装方式与之前类型,还是pip命令:

pip3.6 install flask-sqlalchemy

安装完成之后,对default的配置部分进行修改,首先导入包:

from flask.ext.sqlalchemy import SQLAlchemy

然后配置链接字符串:

app.config["SQLALCHEMY_DATABASE_URI"]='mysql://root:1234@localhost/cblog'

配置请求结束后更改自动提交:

app.config["SQLALCHEMY_COMMIT_ON_TEARDOWN"]=True

实例化SQLAlchemy:

db=SQLAlchemy(app)

模型设置

安装完成之后,继续完善登录的例子,修改default.py文件,新增User模型(类)和Role模型(以示关联)

Role类

class Role(db.Model): #需继承模型
 __tablename__="roles" #db中表明,如果不设置,则会与class同的默认名
 id=db.Column(db.Integer,primary_key=True) #SQLAlchemy要求必须有主键,一般命名为id即可
 name=db.Column(db.String(50),unique=True) #表示name为字符串,不重复
 users=db.relationship("User",backref='role') #关联user模型,并在user中添加反向引用(backref)

User类

class User(db.Model):
 __tablename__="users"
 id=db.Column(db.Integer,primary_key=True)
 username=db.Column(db.String(50),unique=True,index=True) #此列带索引
 password=db.Column(db.String(50))
 role_id=db.Column(db.Integer,db.ForeignKey("roles.id")) #外键指向roles表中的id列

下面要考虑如何执行,要既方便,有不能入侵到逻辑代码,这就要求不能硬编码到逻辑代码中,比如把判断db状态的代码作为参数传递给app.run(),这时候shell就派上了用场

配置脚本

想让flask支持命令行脚本,首先需要安装flask-script扩展:

pip3.6 install flask-script

修改default.py的代码:

from flask.ext.script import Manager

mamager=Manager(app)

....

if __name__=='__main__':
 #app.run(debug=True)
 mamager.run()

修改过之后,再次运行:

python default.py

发现并没有成功运行,而是有提示:

一个基于flask的web应用诞生 flask和mysql相连(4)

可以看到,后边需要参数,分别为shell(执行脚本),runserver(启动服务)和帮助

下边启动服务:

python default.py runserver

服务成功执行

数据库更多配置

但这个时候,访问站点(127.0.0.1:5000),会出现500错误,提示没有mysql模块,这是为什么呢?很明显是没有安装mysql驱动的原因,使用pip命令安装驱动:

pip3.6 install MySQL-python

发现出现错误,显示内容为(此处仅为win系统):

一个基于flask的web应用诞生 flask和mysql相连(4)

根据提示,安装c++的工具包,按照提示上的下载地址

http://landinghub.visualstudio.com/visual-cpp-build-tools

下载完成直接为exe文件,安装

重启后安装MySQL-python,发现还是不可以,经百度后才发现,MySQLdb这个库最高只支持到python2.7,不在支持3.x,那只好用其他办法,使用PyMySQL库:

pip3.6 install PyMySQL

然后修改default.py的代码,增加两行:

import pymysql
pymysql.install_as_MySQLdb()

进入源码,注意这一行:

sys.modules["MySQLdb"] = sys.modules["_mysql"] = sys.modules["pymysql"]

即可成功使用并连接mysql。
浏览器输入连接,正确进入站点。

一个基于flask的web应用诞生 flask和mysql相连(4)

接下来,使用shell建立数据库表,进入default.py根目录:

python default.py shell
from default import db
db.create_all()

这时候如果没有报错,那么数据库表应该建立完成:

一个基于flask的web应用诞生 flask和mysql相连(4)

数据库迁移

那么问题来了,这时候,对模型进行修改,是不会反应到db中的,那么如果修改怎么办呢?对于当前来说,也很简单:

db.drop_all()
db.create_all()

但这个仅仅是现在调试时候使用,如果db中已经有了数据,则这个肯定是无法忍受的,这时候,就轮到数据库迁移插件Migrate登场了,首先还是一样,需要进行安装:

pip3.6 install flask-migrate

和之前一样,安装完之后修改default.py文件进行配置:

from flask.ext.migrate import Migrate,MigrateCommand

migrate=Migrate(app,db) #配置迁移
mamager.add_command("db",MigrateCommand) #配置迁移命令

然后使用init命令初始化迁移仓库

python default.py db init

命令行显示:

一个基于flask的web应用诞生 flask和mysql相连(4)

然后增加migrations目录:

一个基于flask的web应用诞生 flask和mysql相连(4)

表示迁移文件已经初始化完成。

migrate框架提供了一些命令来进行迁移操作,分别为(使用default.py文件举例):

#根据差异创建迁移
python default.py db migrate -m "说明"
#改动差异 
python default.py db upgrade
#取消差异改动
python default.py db downgrade

回到表单

接下来看看登录如何与数据库关联起来,修改login方法内的代码:

@app.route("/login",methods=["POST"])
def loginPost():
 username=request.form.get("username","")
 password=request.form.get("password","")
 user=User.query.filter_by(username=username,password=password).first() #数据库查询
 if user is not None:
 session["user"]=username
 return render_template("/index.html",name=username,site_name='myblog')
 else:
 flash("您输入的用户名或密码错误")
 return render_template("/login.html") #返回的仍为登录页

执行结果非常完美。

一些总结

下面是一些关于python和db相连的总结性的东西

数据类型

一个基于flask的web应用诞生 flask和mysql相连(4)

列选项

一个基于flask的web应用诞生 flask和mysql相连(4)

数据库操作

一个基于flask的web应用诞生 flask和mysql相连(4)

查询过滤器

一个基于flask的web应用诞生 flask和mysql相连(4)

经过这几章,登录功能已经基本完成,在下一章中将讲解用户注册的相关功能。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Hadoop中的Python框架的使用指南
Apr 22 Python
Python多线程经典问题之乘客做公交车算法实例
Mar 22 Python
python3.4用循环往mysql5.7中写数据并输出的实现方法
Jun 20 Python
python3+PyQt5实现文档打印功能
Apr 24 Python
在Python中pandas.DataFrame重置索引名称的实例
Nov 06 Python
使用python的pexpect模块,实现远程免密登录的示例
Feb 14 Python
Django admin.py 在修改/添加表单界面显示额外字段的方法
Aug 22 Python
python科学计算之numpy——ufunc函数用法
Nov 25 Python
django修改models重建数据库的操作
Mar 31 Python
python3.9和pycharm的安装教程并创建简单项目的步骤
Feb 03 Python
教你用Python+selenium搭建自动化测试环境
Jun 18 Python
python读取mat文件生成h5文件的实现
Jul 15 Python
一个基于flask的web应用诞生 bootstrap框架美化(3)
Apr 11 #Python
一个基于flask的web应用诞生 使用模板引擎和表单插件(2)
Apr 11 #Python
非递归的输出1-N的全排列实例(推荐)
Apr 11 #Python
一个基于flask的web应用诞生(1)
Apr 11 #Python
Python 文件处理注意事项总结
Apr 10 #Python
python非递归全排列实现方法
Apr 10 #Python
python 生成器生成杨辉三角的方法(必看)
Apr 10 #Python
You might like
1982年日本摄影师镜头下的中国孩子 那无忧无虑的童年
2020/03/12 杂记
PHILIPS AE3805收音机的分析打磨
2021/03/02 无线电
PHP查看SSL证书信息的方法
2016/09/22 PHP
PHP编程获取各个时间段具体时间的方法
2017/05/26 PHP
PHP实现数据库统计时间戳按天分组输出数据的方法
2017/10/10 PHP
Laravel使用模型实现like模糊查询的例子
2019/10/24 PHP
让firefox支持IE的一些方法的javascript扩展函数代码
2010/01/02 Javascript
JavaScript DOM 学习第七章 表单的扩展
2010/02/19 Javascript
js中的getAttribute方法使用示例
2014/08/01 Javascript
如何高效率去掉js数组中的重复项
2016/04/12 Javascript
Bootstrap每天必学之标签页(Tab)插件
2020/08/09 Javascript
利用AJAX实现WordPress中的文章列表及评论的分页功能
2016/05/17 Javascript
Bootstrap 附加导航(Affix)插件实例详解
2016/06/01 Javascript
BootStrap入门教程(二)之固定的内置样式
2016/09/19 Javascript
原生js实现addclass,removeclass,toggleclasss实例
2016/11/24 Javascript
利用浮层使select不可选的实现方法
2016/12/03 Javascript
jQuery实现鼠标经过显示动画边框特效
2017/03/24 jQuery
jQuery访问浏览器本地存储cookie、localStorage和sessionStorage的基本用法
2017/10/20 jQuery
简单明了区分escape、encodeURI和encodeURIComponent
2018/05/26 Javascript
浅谈webpack SplitChunksPlugin实用指南
2018/09/17 Javascript
微信小程序实现音频文件播放进度的实例代码
2020/03/02 Javascript
[23:21]Ti4 冒泡赛第二轮DK vs C9 2
2014/07/14 DOTA
[00:17]DOTA2荣耀之路5:It’s a disastah!
2018/05/28 DOTA
[06:53]2018DOTA2国际邀请赛寻真——为复仇而来的Newbee
2018/08/15 DOTA
django在接受post请求时显示403forbidden实例解析
2018/01/25 Python
Django接收自定义http header过程详解
2019/08/23 Python
Ray-Ban雷朋美国官网:全球领先的太阳眼镜品牌
2016/07/20 全球购物
芬兰设计商店美国:Finnish Design Shop US
2019/03/25 全球购物
耐克奥地利官网:Nike奥地利
2019/08/16 全球购物
小学教师自我鉴定
2013/11/07 职场文书
大学生演讲稿范文
2014/01/11 职场文书
全国道德模范事迹
2014/02/01 职场文书
乡党政领导班子群众路线教育实践活动个人对照检查材料
2014/09/20 职场文书
2016大学生就业指导课心得体会
2016/01/15 职场文书
MongoDB数据库部署环境准备及使用介绍
2022/03/21 MongoDB
Pandas实现批量拆分与合并Excel的示例代码
2022/05/30 Python