Flask组件
组件踩坑记录 : 先注册组件在使用配置(...)
flask-script
Flask Script扩展提供向Flask插入外部脚本的功能,包括运行一个开发用的服务器,一个定制的Python shell,设置数据库的脚本,cronjobs,及其他运行在web应用之外的命令行任务;使得脚本和系统分开;
Flask Script和Flask本身的工作方式类似,只需定义和添加从命令行中被Manager实例调用的命令;
安装
pip install flask-script
创建并运行命令
首先,创建一个Python模板运行命令脚本,可起名为manager.py;
在该文件中,必须有一个Manager实例,Manager类追踪所有在命令行中调用的命令和处理过程的调用运行情况;
Manager只有一个参数——Flask实例,也可以是一个函数或其他的返回Flask实例;
调用manager.run()启动Manager实例接收命令行中的命令;
from flask_script import Manager
from debug import app manager = Manager(app) if __name__ == '__main__':
manager.run()
然后就可以在项目目录下执行命令来启动项目了
python manage.py runserver
创建更多命令
from flask_script import Manager
from flask import Flask app = Flask(__name__)
manager = Manager(app) @manager.command
def custom(arg):
"""
自定义命令
python manage.py custom 123
:param arg:
:return:
"""
print(arg) @manager.option('-n', '--name', dest='name')
@manager.option('-u', '--url', dest='url')
def cmd(name, url):
"""
自定义命令
执行: python manage.py cmd -n wupeiqi -u http://www.oldboyedu.com
执行: python manage.py cmd --name wupeiqi --url http://www.oldboyedu.com
:param name:
:param url:
:return:
"""
print(name, url) if __name__ == '__main__':
manager.run()
flask-sqlalchemy
将flask与sqlalchemy封装到了一起,并且是基于线程隔离的方式
使用
实例化SQLAlchemy对象,将Flask对象注册进SQLAlchemy对象中
from flask import Flask
from flask_sqlalchemy import SQLAlchemy # 包含了SQLAlchemy相关的所有操作
db = SQLAlchemy() app = Flask(__name__)
app.config.from_object('settings.DevelopmentConfig') from .views.account import ac
# 导入蓝图时应注意蓝图中可能导入了db对象,所以要在db对象生成后导入
app.register_blueprint(ac) db.init_app(app)
配置文件设置
class BaseConfig(object):
SQLALCHEMY_DATABASE_URI = "mysql+pymysql://root:123456@127.0.0.1:3306/s8day130db?charset=utf8"
SQLALCHEMY_POOL_SIZE = 5
SQLALCHEMY_POOL_TIMEOUT = 30
SQLALCHEMY_POOL_RECYCLE = -1
模型类:
from sqlalchemy import Column, Integer, String
from s8day130_pro import db class Users(db.Model):
__tablename__ = 'users'
id = Column(Integer, primary_key=True,autoincrement=True)
name = Column(String(32),nullable=False,unique=True)
离线脚本生成表/删除表
# 导入db
# 导入app
with app.app_context():
db.drop_all()
# db.create_all()
踩坑记录1 -- 无法生成表, 解决方法 : 把所有的模型导入
在视图函数中使用SQLAlchemy操作数据库
from flask import blueprints
ac = blueprints.Blueprint('ac',__name__) @ac.route('/login',methods=['GET','POST'])
def login():
data = db.session.query(models.Users).all()
print(data)
db.session.remove()
return 'Login'
flask-migrate
帮助flask做数据库迁移,他是基于flask-script和flask-migrate来做的
安装
pip install flask-migrate
使用
# 导入db,app
from flask_script import Manager
from flask_migrate import Migrate, MigrateCommand manager = Manager(app)
migrate = Migrate(app, db) """
# 数据库迁移命名
python manage.py db init
python manage.py db migrate
python manage.py db upgrade
"""
manager.add_command('db', MigrateCommand)
自定义一个登陆验证的组件
from flask import request,session,redirect class Auth(object): def __init__(self,app=None):
self.app = app
if app:
# 实例化时完成注册
self.init_app(app) def init_app(self,app):
# 也可手动完成注册过程
app.auth_manager = self # 将自身添加进app中 self.app = app
app.before_request(self.check_login) # 添加一个before_request
app.context_processor(self.context_processor) # 向模板中添加新的变量 def check_login(self):
"""
检查用户是否已经登录
:return:
"""
if request.path == '/login':
return user = session.get('user')
if not user:
return redirect('/login') def context_processor(self):
user = session.get('user')
return dict(current_user=user) def login(self,data):
"""
将用户登录信息,放入session
:param data:
:return:
"""
session['user'] = data def logout(self):
"""
将用户登录信息,放入session
:param data:
:return:
"""
del session['user']
Flask组件的更多相关文章
- Flask组件 flask_session
flask-session是flask框架的session组件,由于原来flask内置session使用签名cookie保存,该组件则将支持session保存到多个地方,如: redis memcac ...
- 第五篇 Flask组件之SQLAchemy及Flask-SQLAlchemy插件/Flask-Script/Flask-migrate/pipreqs模块
SQLAlchemy组件 一. 介绍 SQLAlchemy是一个基于Python实现的ORM框架.该框架建立在 DB API之上,使用关系对象映射进行数据库操作,简言之便是:将类和对象转换成SQL,然 ...
- Flask组件:flask-sqlalchemy & flask-script & flask-migrate
flask-sqlalchemy组件 项目目录结构: flask目录 # 项目名 |--- flaskdir |--- static # 静态文件 |--- templates # 模板 |--- m ...
- flask组件之flask_script和flask_migrate的使用
flask_script的使用 作用: 使用命令启动flask项目 # 在项目的启动文件中 from flask import Flask from settings import Settings ...
- 【Flask】 WTForm表单编程
WTForm表单编程 在网页中,为了和用户进行信息交互总是不得不出现一些表单.flask设计了WTForm表单库来使flask可以更加简便地管理操作表单数据.WTForm中最重要的几个概念如下: Fo ...
- Flask 源码流程,上下文管理
源码流程 创建对象 from flask import Flask """ 1 实例化对象 app """ app = Flask(__na ...
- Flask框架基础--第一篇
1.flask框架和其他几种框架的优缺点对比 Django : 优点 - 大而全所有组件都是有组织内部开发高度定制化 教科书级别的框架 缺点 - 大到浪费资源,请求的时候需要的资源较高 Flask : ...
- flask重要点
django与flask的区别 django: 大而全的框架,包含了很多组件,例如:ORM.form.ModelForm.session... flask: 轻量级的可扩展强的框架.有丰富的第三方组件 ...
- 初始Flask
一.Flask介绍(轻量级的框架,非常快速的就能把程序搭建起来) Flask 主要特点小而轻,原生组件几乎为0, 三方提供的组件请参考Django 非常全面,属于短小精悍型框架 Flask是一个基于P ...
随机推荐
- myeclipse使用步骤总结
1.安装和破解:http://www.cnblogs.com/haimishasha/p/5203069.html 2.修改编码方式:http://www.cnblogs.com/haimishash ...
- Linux记录-文件格式
yum -y install dos2unix dos2unix filename
- 来自Composer中文网安装composer指南
如果有需要安装composer的童鞋可以参考这个文章配置自己的composer https://pkg.phpcomposer.com/#how-to-install-composer 这里可能会出很 ...
- HDU 1030(三角数阵 数学)
题意是问在给定的三角形数阵中从一个数到另一个数所要跨过的边数. 最初的时候很迷,除了发现每层的数字个数与层数间的关系和每层数最后一个数与层数的关系外什么也没看出来,打算先求出数字所在的层数,然后计算到 ...
- MVC、MVP和MVVC区别
https://blog.csdn.net/victoryzn/article/details/78392128
- 细说ORM之Entity FrameWork系列(被替换)
一. 谈情怀 从第一次接触开发到现在(2018年),接近五年时间了,最初阶段连接数据库,使用的是[SQL语句+ADO.NET],那时候,什么存储过程.什么事务 统统不理解,生硬的将SQL语句传入SQL ...
- vue基于组件实现简单的todolist
把todolist拆分为header.footer.list三个模块 index文件 <!DOCTYPE html> <html lang="en"> &l ...
- flask请求异步执行(转载)
Flask默认是不支持非阻塞IO的,表现为: 当 请求1未完成之前,请求2是需要等待处理状态,效率非常低. 在flask中非阻塞实现可以由2种: 启用flask多线程机制 # Flask from f ...
- 酷狗.kgtemp文件加密算法逆向
该帖转载于孤心浪子--http://www.cnblogs.com/KMBlog/p/6877752.html 酷狗音乐上的一些歌曲是不能免费下载的,然而用户仍然可以离线试听,这说明有缓存文件,并且极 ...
- Android获取版本号
public static String getVersionName(Context context) { PackageManager manager = context.getPackageMa ...