【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不使用元类创建缓存实例
问题 当创建类实例时我们想返回一个缓存引用,让其指向上一个用同样参数(如果有的话)创建出来的类实例. 这个问题常常出现在当我们想确保针对一组输入参数只会有一个类实例存在时. 解决方法: 使用一个与类本 ...
随机推荐
- dedecms 列表 用分页标签 判断 当第一页则显示,第二页以上不显示 土办法!
arc.listview.class.php function GetPageListST($list_len,$listitem="index,end,pre,next,pageno,sp ...
- maven 依赖包找不到 (转)
1,手动添加jar包 例: maven在集成Oracle驱动的时候从远程仓库下载不下来ojdbc14 报missing artifact com.oracle:ojdbc14:jar:10.2.0.3 ...
- 因xhost命令和DISPLAY环境变量操作不当导致无法启动Oracle图形化安装界面
在redhat操作系统上安装Oracle 11.1时,遇到在执行runInstaller后无法启动安装图像化界面,甚是郁闷. 问题现象: 使用Xmanager2.0软件登陆AIX桌面,root用户可以 ...
- shell 脚本中的入参获取与判断
1.获取shell脚本的入参个数: $# 2.获取shell脚本的第n个入参的字符个数/字符串长度(注意这里的n需要替换为具体的数字,如果这个数字超过实际的入参个数,结果为0): ${#n}
- nginx反向代理实现后端web的读写分离
1.环境 角色 ip 主机名 负载均衡节点 10.0.0.11 nginx-lb01 可读写web01节点 10.0.0.12 nginx-web01 只读web02节点 10.0.0.13 ngin ...
- 模拟赛小结:2017-2018 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2017)
比赛链接:传送门 本场我们队过的题感觉算法都挺简单的,不知道为啥做的时候感觉没有很顺利. 封榜后7题,罚时1015.第一次模拟赛金,虽然是北欧的区域赛,但还是有点开心的. Problem B Best ...
- 双向BFS统计
Hdu1195 两个四位密码 问你最少多少步能到达 /*Huyyt*/ #include<bits/stdc++.h> #define mem(a,b) memset(a,b,sizeof ...
- pandas的dataframe与spark的dataframe
- 【LOJ#536】「LibreOJ Round #6」花札
题目链接 题目描述 「UniversalNO」的规则如下:每张牌有一种颜色和一个点数.两个人轮流出牌,由 Alice 先手,最开始牌堆为空,出的人可以出任意牌(放到牌堆顶),之后出的牌必须和当时牌堆顶 ...
- web前端_js
在HTML中可以将JavaScript/JS的代码写在head中,被script标签所包裹,当浏览器解释HTML时,遇到style标签时,按照CSS规则解释,遇到Script标签时,按照JavaScr ...