轻量级Web框架Flask
Posted yetangjian
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了轻量级Web框架Flask相关的知识,希望对你有一定的参考价值。
Flask-SQLAlchemy
MySQL是免费开源软件,大家可以自行搜索其官网(https://www.MySQL.com/downloads/)
测试MySQL是否安装成功
在所有程序中,找到MySQL→MySQL Server 5.6下面的命令行工具,然后单击输入密码后回车,就可以知道MySQL数据库是否链接成功。
右击桌面上的“计算机”,在弹出的快捷键菜单中选择“属性”|“高级系统设置”|“环境变量”,在path里面添加MySQL bin目录的路径。选择环境变量,在环境变量中的path路径下输入你的MySQL路径就行了。默认安装的路径是C:\\MySQL\\MySQL Server 5.6\\bin
安装flask-sqlalchemy,安装不了就更换豆瓣源
pip install flask-sqlalchemy
对象-关系映射实质
class Lib_card(db.Model): __tablename__ = \'lib_card\' id = db.Column(db.Integer, primary_key=True, comment=\'id号\') card_id = db.Column(db.Integer, nullable=False, comment = \'借书证\') book_id = db.Column(db.Integer, db.ForeignKey(\'book.id\')) books = db.relationship(\'Book\', backref=db.backref(\'cards\'),uselist=False)
在Flask-SQLAlchemy中,插入、修改、删除操作均由数据库会话管理
需要一个配置config.py
USERNAME= \'root\' #设置登录账号 PASSWORD= \'930103\' #设置登录密码 HOST= \'127.0.0.1\' #设置主机地址 PORT= \'3306\' #设置端口号 DATABASE= \'demo1\' #设置访问的数据库 SQLALCHEMY_DATABASE_URI= f\'mysql+pymysql://USERNAME:PASSWORD@HOST:PORT/DATABASE\'#创建数据库连接示例 #动态追踪修改设置,如未设置只会提示警告 SQLALCHEMY_TRACK_MODIFICATIONS=False #查询时会显示原始SQL语句 SQLALCHEMY_ECHO= True
实例
from datetime import datetime from flask import Flask #导入Flask模块 from flask_sqlalchemy import SQLAlchemy #导入SQLAlchemy模块 import config #导入配置文件 app= Flask(__name__) #Flask初始化 app.config.from_object(config) #配置文件实例化 #初始化一个对象 db=SQLAlchemy(app) class Book(db.Model): __tablename__ = \'book\' id = db.Column(db.Integer, primary_key = True,comment=\'id号\') title = db.Column(db.String(50), nullable=False,comment=\'书名\') publishing_office = db.Column(db.String(100), nullable=False,comment=\'出版社\') isbn = db.Column(db.String(100), nullable=False, comment=\'isbn号\') storage_time = db.Column(db.DateTime, default=datetime.now(), comment=\'入库时间\') class Lib_card(db.Model): __tablename__ = \'lib_card\' id = db.Column(db.Integer, primary_key=True, comment=\'id号\') card_id = db.Column(db.Integer, nullable=False, comment = \'借书证\') book_id = db.Column(db.Integer, db.ForeignKey(\'book.id\')) books = db.relationship(\'Book\', backref=db.backref(\'cards\'),uselist=False) with app.app_context(): #测试数据库连接是否成功 db.create_all() #创建数据库 # book1= Book(id=9,title=\'智能导论\', publishing_office=\'高等教育出版社\',isbn=\'9787040479844\') # db.session.add(book1) # db.session.commit() # result = Book.query.filter(Book.id == 9).first() # print(result.title) # agine = Book.query.filter(Book.title == result.title).all() # for i in agine: # print(i.id) # db.session.delete(result) # db.session.commit() # card1=Lib_card(card_id=\'18001\', book_id=\'8\') # card2=Lib_card(card_id=\'18002\', book_id=\'8\') # db.session.add(card1) # db.session.add(card2) # db.session.commit() book_query = Book.query.filter(Book.id == 9).first() lib_card_query = book_query.cards for i in lib_card_query: print(i.card_id) @app.route(\'/\') def index(): return \'index\' # if __name__== \'__main__\': # app.run(debug=True)
注意:一个表(模型)的定义必须要定义一个主键,这个主键一般为id。在定义了Lib_card类后,申明了一个外键,并且在relationship方法中使用uselist=False来约束其关系。book_id =db.Column(db.Integer,db.ForeignKey(\'book.id\'))表示创建一个外键,类型要跟主表一样,通过db.ForeignKey("user.id")与主表绑定books =db.relationship(\'Book\',backref=db.backref(\'cards\');uselist=False)表示Book可以根据Lib_card中的借书证查找到book表中的信息,backref="cards"表示book表可以直接通过cards查找到该书下的借书证号码。
框架实例
建一个apps文件夹,添加一个admin包,admin包下创建三个py文件
#__init__.py #预加载模块内容 #其他地方调用的时候 可以直接from apps.admin import bp as admin_bp不用找到views from .views import bp
#forms.py from flask_wtf import FlaskForm from wtforms import * from wtforms.validators import * class NameForm(FlaskForm): username = StringField(\'用户名\',validators=[DataRequired()]) password = PasswordField(\'密码\',validators=[DataRequired()]) submit = SubmitField(\'提交\')
#models.py from exts import db class User(db.Model): __tablename__ = \'jq_user\' uid = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(50), nullable=False, comment="用户名") password = db.Column(db.String(100), nullable=False,comment="密码") email = db.Column(db.String(50), nullable=False, unique=True, comment = "邮箱")
#views.py from flask import Blueprint, request, flash, render_template from apps.admin.forms import NameForm from apps.admin.models import User bp = Blueprint("admin",__name__) @bp.route("/admin",methods=[\'GET\',\'POST\']) def index(): form = NameForm() if request.method == \'POST\': if form.validate_on_submit(): username = request.form.get(\'username\') password = request.form.get(\'password\') result = User.query.filter(User.username==username).first() if result and password == result.password: flash(\'登录成功\') else: return render_template(\'login.html\', form=form, errormsg="登陆失败") return render_template(\'login.html\', form=form)
建一个文件夹templates,专门放login.html文件,通过render_template调用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <h1>用户注册登录</h1> <form method="post" action="/test/admin"> form.csrf_token() form.username.label form.username form.password.label form.password form.submit errormsg % for message in get_flashed_messages() % message % endfor % </form> </head> <body> </body> </html>
建一个app.py
from flask import Flask from apps.admin import bp as admin_bp from exts import db from apps.common import bp as common_bp from apps.front import bp as front_bp from apps.admin.models import User from apps.common.models import Book def create_app(): app = Flask(__name__) app.secret_key = \'123321\' #注册蓝图,注册时候可以设置前缀 app.register_blueprint(admin_bp,url_prefix="/test") app.register_blueprint(common_bp) app.register_blueprint(front_bp) app.config.from_object(\'config\') # db.app = app db.init_app(app) return app if __name__ == \'__main__\': app = create_app() with app.app_context(): db.create_all() app.run(host="127.0.0.1",port=1314,debug=True)
建一个config.py
DEBUG=True USERNAME= \'root\' #设置登录账号 PASSWORD= \'930103\' #设置登录密码 HOST= \'127.0.0.1\' #设置主机地址 PORT= \'3306\' #设置端口号 DATABASE= \'demo1\' #设置访问的数据库 SQLALCHEMY_DATABASE_URI= f\'mysql+pymysql://USERNAME:PASSWORD@HOST:PORT/DATABASE\'#创建数据库连接示例 #动态追踪修改设置,如未设置只会提示警告 SQLALCHEMY_TRACK_MODIFICATIONS=False #查询时会显示原始SQL语句 SQLALCHEMY_ECHO= True
建一个exts.py
#encoding:utf-8 from flask_sqlalchemy import SQLAlchemy db=SQLAlchemy()
作者: yetangjian
出处: https://www.cnblogs.com/yetangjian/p/17320268.html
关于作者: yetangjian
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 原文链接 如有问题, 可邮件(yetangjian@outlook.com)咨询.
Python轻量Web框架Flask使用
Python语言近些年越来越火,其特点是开发迅速,语法简单,可移植等。本人就Python3基础语法写了Demo:https://github.com/tangthis/python3_demo,可以当作基础教程和手册查阅。
Python Web开发框架常用的包括Django,Flask,Tornado,Bottle,web.py,Quixote等。Django功能比较全面,比较重,相对来说,Flask更加轻巧,适合新手学习和上手。下面介绍下Flask基本使用,包括以下内容:
Flask安装
1.安装Python3
从Python的官方网站下载Python 3.4对应的64位安装程序或32位安装程序(网速慢的同学请移步国内镜像)
64位:https://www.python.org/ftp/python/3.4.3/python-3.4.3.amd64.msi
32位:https://www.python.org/ftp/python/3.4.3/python-3.4.3.msi
国内镜像:http://pan.baidu.com/s/1sjqOkFF
安装时,要选择pip和Add python.exe to Path选项,如下图
2.安装Flask框架
打开命名行窗口,执行下面命令
pip install flask
pip install flask-login
pip install flask-openid
pip install flask-sqlalchemy
pip install sqlalchemy-migrate
pip install flask-whooshalchemy
pip install flask-wtf
pip install flask-babel
pip install flup
Python开发工具Eclipse+PyDev准备
1.下载PythonDev插件
http://sourceforge.net/projects/pydev/
2.解压pydev插件后,会发现有features、plugins两个文件夹,然后把features文件夹下的文件移到D:\dev\eclipse\features目录下,把plugins文件夹下的文件移到D:\dev\eclipse\plugins目录下
3.重启eclipse,在windows->preferences出现PyDev配置项,表示PyDev插件安装成功
4.配置PyDev
windows->preferences->PyDev->Interpreter - Python,New一个Python解释器,填上解释器名字和路径,路径选相应的python.exe
至此,PyDev配置完了
Flask项目框架搭建
1.新建Python项目
File->New->PyDev Project
2.新建项目结构文件夹
app–根目录
static–静态资源目录,图片,js,css等
templates–模板
_init_.py–初始化脚本
views.py–视图控制器
tmp–临时文件夹
run.py–项目启动程序
3.通过Flask,创建神奇的Hello World程序
_init_.py创建Flask实例
from flask import flash
app = Flask(__name__)
from app import views
run.py创建启动脚本
from app import app
app.run(debug = True)
在app目录下,创建views.py,加入下面代码
from app import app
@app.route("/")
def index():
return "hello,world!"
4.启动程序
python run.py
5.访问http://localhost:5000/,返回hello,world
MVC模式实例开发
Controller使用介绍
拦截/index请求
@app.route("/index")
def index():
return ‘index‘
拦截Post或者Get方法
@app.route("/index",methods = [‘GET‘])
def index():
return ‘index‘
Restful支持
@app.route("/index/<username>")
def index(username):
return username
登录实例
我们通过一个登录的例子来展示完整的MVC流程
1.创建LoginForm登录表单
app->新建forms.py,继承Flask Form类
from flask.ext.wtf import Form
from wtforms import TextField,PasswordField
from wtforms.validators import Required,Length
class LoginForm(Form):
username= TextField(‘username‘,validators = [Required()])
password = PasswordField(‘username‘,validators = [Required()])
2.登录页面login.html
app->template->新建login.html
<h1>登录</h1>
<form action="" method="post" name="login">
<p>
请输入用户名:<br>
{{form.username(size=30)}}<br>
</p>
<p>
请输入用户名:<br>
{{form.password(size=30)}}<br>
</p>
<p><input type="submit" value="登录"></p>
</form>
3.登录控制器Controller
from app import app
@app.route(‘/login‘,methods = [‘GET‘ , ‘POST‘])
def login():
#接收参数
form = LoginForm()
#提交验证
if form.validate_on_submit():
#打印(ps:验证逻辑自行补上)
print(‘username:‘ + form.username.data + ‘,password:‘ + form.password.data)
#返回到index.html页面
return render_template(‘index.html‘,form = form)
#未提交
return render_template(‘login.html‘,form = form)
4.登录成功页面index.html
<h1>Hi,{{form.username}}!</h1>
通过上面几步,一个使用Flask开发的简单的登录逻辑完成,可以看出来开发效率之高。更多Flask内容,请下载github微博Weibo实例源码
github源码:https://github.com/tangthis/Weibo
以上是关于轻量级Web框架Flask的主要内容,如果未能解决你的问题,请参考以下文章