【flask】使用类组织配置-使用工厂函数创建程序实例
【需求】
使用配置类管理flask管理测试环境,
通过1个参数即可控制Flask是运行develpment环境还是production环境(数据库配置,邮件配置也要根据环境的变化而变化)
【思路】
1.在config.ini中存储所有的配置信息
2.在settings.py通过DdevelopConfig,ProductionConfig类存取不同测试环境 的环境变量值
3.在app.py通过实例化DdevelopConfig或ProductionConfig类,获取这些类中的环境变量的值
在创建Flask对象app之后,通过方法app.config.from_object(obj)将配置信息写入到app.config
这样最终的效果就是:
在创建app时,通过create_app(config_name),即可灵活的切换测试环境
【代码示例】
目录结构:
config.ini
# Flask对象配置
[app]
FLASK_CONFIG=production
JSON_AS_ASCII =False
JSONIFY_MIMETYPE = "application/json;charset=utf-8"
SECRET_KEY='secret string' # 数据库配置
[sqlalchemy]
SQLALCHEMY_TRACK_MODIFICATIONS=False # 线上环境
[production]
DATABASE_URL ='mysql+mysqlconnector://username:password@ip:port/dbname?charset=utf8' # 开发环境
[development]
DATABASE_URL ='mysql+mysqlconnector://username:password@ip:port/dbname?charset=utf8' # 邮件配置信息
[email]
MAIL_SERVER="smtp.126.com"
MAIL_USERNAME='xxxx@126.com'
MAIL_PASSWORD="授权码"
settings.py
import os
from configparser import ConfigParser basedir = os.path.abspath(os.path.dirname(__file__))
cfgpath = os.path.join(basedir, 'config.ini')
cf = ConfigParser()
cf.read(cfgpath) # 获取邮件配置
def get_email_config(option):
return cf.get('email', option) # 获取邮件配置
def get_app_config(option):
return cf.get('app', option) # 获取数据库配置
def get_sqlalchemy_config(option):
return cf.get('sqlalchemy', option) # 获取生产环境配置
def get_production_config(option):
return cf.get('production', option) # 获取开发环境配置
def get_development_config(option):
return cf.get('development', option) class BaseConfig(object):
SECRET_KEY = get_app_config('SECRET_KEY') SQLALCHMEY_TRACK_MODIFICATIONS = False MAIL_SERVER = get_email_config('MAIL_SERVER')
MAIL_PORT = 465
MAIL_USE_SSL = True
MAIL_USERNAME = get_email_config('MAIL_USERNAME')
MAIL_PASSWORD = get_email_config('MAIL_USERNAME')
MAIL_DEFAULT_SENDER = ('Bluelog Admin', MAIL_USERNAME) class DevelopmentConfig(BaseConfig):
ENV = 'development'
AAA = 'in DevelopmentConfig'
SQLALCHEMY_DATABASE_URI = get_development_config('DATABASE_URL') class ProductingConfig(BaseConfig):
ENV = 'production'
AAA='in ProductingConfig'
SQLALCHEMY_DATABASE_URI = get_production_config('DATABASE_URL') config = {
'production': ProductingConfig,
'development': DevelopmentConfig
}
app.py
from flask import Flask
from settings import config,get_app_config def create_app(config_name=None):
# 不指定config_name,默认取配置文件FLASK_CONFIG的值
# 指定config_name,则以指定的环境为主
if config_name is None:
config_name=get_app_config('FLASK_CONFIG')
app = Flask(__name__)
cfobj=config[config_name]
app.config.from_object(cfobj) return app #测试不指定config_name
app = create_app()
print(app.config['FLASK_ENV'])
print(app.config['AAA'])
print('*'*50)
#测试指定config_name
app = create_app('development')
print(app.config['FLASK_ENV'])
print(app.config['AAA'])
运行结果:
production
in ProductingConfig
**************************************************
development
in DevelopmentConfig
重点:
使用该种方法组织Flask程序后,如果想单独运行models文件(使用if __name__ == '__main__'),查询数据,会报错
if __name__ == '__main__':
from flask import Flask
from flask_sqlalchemy import SQLAlchemy app = Flask(__name__)
db = SQLAlchemy(app) search_case_objs = TestCase.query.filter_by(creater='王菊')
print(search_case_objs)
报错如下:
RuntimeError: No application found. Either work inside a view function or push an application context. See http://flask-sqlalchemy.pocoo.org/contexts/.
正确的调试方法:
- 运行wsgi文件
- 在Terminal中输入flask shell,在flask shell中导入从models中导入要查询的表,接下来就可以执行curd了
>>> from gotest.models import TestCase
>>> a=TestCase.query.filter_by(creater=<name>)
>>> a
<flask_sqlalchemy.BaseQuery object at 0x7f5c5087c080>
>>> type(a)
<class 'flask_sqlalchemy.BaseQuery'>
>>> a=TestCase.query.filter_by(creater=<name>).all()
>>> a
[<TestCase.a11bcdecdefd1111111111111111111111ffd>, <TestCase.获取xxxxxx评价>]
【flask】使用类组织配置-使用工厂函数创建程序实例的更多相关文章
- flask实战-个人博客-使用工厂函数创建程序实例 --
使用工厂函数创建程序实例 使用蓝本还有一个重要的好处,那就是允许使用工厂函数来创建程序实例.在OOP(Object-Oriented Programming,面向对象编程)中,工厂(factory)是 ...
- flask实战-个人博客-使用类组织配置
使用类组织配置 在实际需求中,我们往往需要不同的配置组合.例如,开发用的配置,测试用的配置,生产环境用的配置.为了能方便地在这些配置中切换,你可以把配置文件升级为包,然后为这些使用场景分别创建不同的配 ...
- Spring工厂方式创建Bean实例
创建Bean实例的方式: 1) 通过构造器(有参或无参) 方式: <bean id="" class=""/> 2) 通过静态工厂方法 方式: &l ...
- flask中用类的方式构造视图函数
from flask import Flask from flask.views import MethodView app = Flask(__name__) class IndexView(Met ...
- js工厂函数
经常会遇到工厂函数这个词,不过javascript不是严格的面向对象语言,不像java,C#拥有类,所以工厂函数会变得比较模糊. 简单来讲,就是创建一个可以用来创建实例的函数,这样每一个实例都是独立的 ...
- JavaScript中的构造函数和工厂函数说明
在cnblog上看到一篇文章,讲解JS中的构造函数和工厂函数,觉得讲的真好 JavaScript中的工厂函数和构造函数都能用来创建一个对象,我们可以来看看下面的例子 构造函数 function cre ...
- js工厂函数创建对象与对象构造函数的理解
工厂函数,顾名思义,就是通过一个"工厂的加工" 来创建一个对象的函数 //工厂函数 function createPerson(name,sex){ sex = sex == '男' ? '女' : ...
- Abstract Factory 抽象工厂(创建型模式)
1.常规的对象创建方法(以更换QQ空间主题为例) (这里的常规对象指的是由于业务需求,当前实例化的对象有可能被其他相似的对象(有着共同的特性)所取代,例如更换手机铃声:一首歌取代另一首歌(词,曲,和声 ...
- Python不使用元类创建缓存实例
问题 当创建类实例时我们想返回一个缓存引用,让其指向上一个用同样参数(如果有的话)创建出来的类实例. 这个问题常常出现在当我们想确保针对一组输入参数只会有一个类实例存在时. 解决方法: 使用一个与类本 ...
随机推荐
- 线程安全的Singleton要点
1.privat static Singleton 要加votatile关键字修饰,防止对象的初始化代码与引用赋值代码进行重排序. 2.getInstance方法,最外层要加if (instance ...
- MySQL快速清空表数据
truncate table 可以不删除表的情况下,快速情况表数据
- QT 托盘 hover事件捕捉
1. QSystemTrayIcon hover事件 参考:https://stackoverflow.com/questions/21795919/how-to-catch-the-mousehov ...
- Excel 曝Power Query安全漏洞
近日,Mimecast 威胁中心的安全研究人员,发现了微软 Excel 电子表格应用程序的一个新漏洞,获致 1.2 亿用户易受网络攻击.其指出,该安全漏洞意味着攻击者可以利用 Excel 的 Powe ...
- 简单xml示例
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.X ...
- oracle 清空当前用户所有对象
BEGIN FOR REC IN (SELECT OBJECT_NAME,OBJECT_TYPE FROM USER_OBJECTS WHERE OBJECT_TYPE='PROCEDURE' OR ...
- 【未知来源】Happy
题意 给出一个 \(n\) 个节点的树,两点之间有且仅有一条路径相连. 给出 \(m\) 个点对 \(x_i,y_i\),如果添加一条双向边 \((u,v)\) 后 \(x_i\) 和 \(y_i\) ...
- CSS中cursor属性
光标类型 CSS十字准心 cursor: crosshair;手 cursor: pointer;cursor: hand;写两个是为了照顾IE5,它只认hand.等待/沙漏 cursor: wa ...
- 【BZOJ3534】【Luogu P3317】 [SDOI2014]重建 变元矩阵树,高斯消元
题解看这里,主要想说一下以前没见过的变元矩阵树还有前几个题见到的几个小细节. 邻接矩阵是可以带权值的.求所有生成树边权和的时候我们有一个基尔霍夫矩阵,是度数矩阵减去邻接矩阵.而所谓变元矩阵树实际上就是 ...
- html中删除表格的一行(有弹窗)
html中删除表格一行其实很简单,但是加上一个提示弹窗后,点击确定后却获取不到要删除的是哪一行,下面是一个demo html: <tr> <td> <input type ...