原理如下:

 
image.png

1、通过调用自定义config.py文件中config字典,可以得到一个类,
这个类里面定义的都是类变量,这些变量就是自定义的一些配置项。
如下config.py : :

import os

BASEDIR = os.path.abspath(os.path.dirname(__file__))

class Config:
"""base config"""
SECRET_KEY = os.environ.get('SECRET_KEY') or 'secret key'
SQLALCHEMY_COMMIT_ON_TEARDOWN = True
SQLALCHEMY_TRACK_MODIFICATIONS = True
FLASKY_ADMIN = os.environ.get('FLASKY_ADMIN') FLASKY_MAIL_SENDED = 'jianghan@julanling.com' # 发件人地址
FLASKY_MAIL_SUBJECT_PREFIX = '[Flasky]' # 邮件主题前缀 class ProductionConfig(Config):
"""运行环境配置"""
SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL') or \
'sqlite:///' + os.path.join(BASEDIR, 'data.sqlite')
...... config = {
'development': DevelopmentConfig,
'testing': ProductionConfig,
'production': ProductionConfig,
'default': DevelopmentConfig
}

2、利用Flask类,实例app,并把自定义配置传进去。
如下app.py:

# __name__是本文件名字,
# Flask类里面,会根据此名字,找到app.py所在目录,即默认为根目录。
app = Flask(__name__)
app.config.from_object(config['testing'])

3、配置原理:

自定义配置类给到app.config。
app.config 来自于 self.make_config()
self.make_config() 返回的值是 config_class()
config_class 就是Config类。
config_class(),是config加个括号,其实就是Config()

通过上面一系列的串联,可以看出:
app.config,就是Config()

之所以要在中间加一些方法,如mke_config(),是为了给Config()添加一些默认值。
例如:根目录root_path、默认配置self.default_config等。
如下:

    def make_config(self, instance_relative=False):
root_path = self.root_path
if instance_relative:
root_path = self.instance_path
return self.config_class(root_path, self.default_config)

其实,在你在写到app.config时,就已经创建了一个带默认配置项的Config()实例。
Config类有很多方法可以修改默认配置和添加新配置。如from_object()

当写到 app.config.from_object(config),其实就是对默认配置的修改和添加。

参考:很多,在网上了其他人的一些解释,然后自己再看看源码,就大概明白了。

logging模块

flask配置日志

代码

from logging.handlers import RotatingFileHandler
from flask import Flask, request
import logging
app = Flask(__name__)
app.config['PROPAGATE_EXCEPTIONS'] = False # 设置是否传递异常 , 如果为True, 则flask运行中的错误会显示到网页中, 如果为False, 则会输出到文件中 class RequestFormatter(logging.Formatter): # 自定义格式化类
def format(self, record):
"""每次生成日志时都会调用, 该方法主要用于设置自定义的日志信息
:param record 日志信息"""
record.url = request.url # 获取请求的url
record.remote_addr = request.remote_addr # 获取客户端的ip return super().format(record) # 执行父类的默认操作 # flask中提供了两个日志 1> werkzeug 记录web应用运行中出现的错误 2> flask.app 给开发者预留的日志
# flask中的运行错误也会记录到flask.app的日志中
def create_logger():
"""配置flask日志"""
# 创建flask.app日志器
flask_logger = logging.getLogger('flask.app')
# 设置全局级别
flask_logger.setLevel('DEBUG') # 创建控制台处理器
console_handler = logging.StreamHandler() # 给处理器设置输出格式
console_formatter = logging.Formatter(fmt='%(name)s %(levelname)s %(pathname)s %(lineno)d %(message)s')
console_handler.setFormatter(console_formatter) # 日志器添加处理器
flask_logger.addHandler(console_handler) # 创建文件处理器
file_handler = RotatingFileHandler(filename='flask.log', maxBytes=100 * 1024 * 1024, backupCount=10) # 转存文件处理器 当达到限定的文件大小时, 可以将日志转存到其他文件中 # 给处理器设置输出格式
file_formatter = RequestFormatter(fmt='[%(asctime)s] %(remote_addr)s requested %(url)s %(name)s %(levelname)s %(pathname)s %(lineno)d %(message)s')
file_handler.setFormatter(file_formatter)
# 单独设置文件处理器的日志级别
file_handler.setLevel('WARN') # 日志器添加处理器
flask_logger.addHandler(file_handler) @app.route('/')
def index():
# num = 1 / 0
app.logger.error('this is a error')
return "index" if __name__ == '__main__':
create_logger()
app.run(debug=True)

自定义日志信息

项目中配置日志

  • 在 家目录中手动创建log文件夹
# 查看最新的⽇日志
tail flask.log # 默认查看最新的10⾏行行⽇日志
tail -n 100 flask.log # 默认查看最新的100⾏行行⽇日志
tail -f flask.log # 动态监听⽇日志

Flask app.config 的配置的更多相关文章

  1. c#Winform程序调用app.config文件配置数据库连接字符串 SQL Server文章目录 浅谈SQL Server中统计对于查询的影响 有关索引的DMV SQL Server中的执行引擎入门 【译】表变量和临时表的比较 对于表列数据类型选择的一点思考 SQL Server复制入门(一)----复制简介 操作系统中的进程与线程

    c#Winform程序调用app.config文件配置数据库连接字符串 你新建winform项目的时候,会有一个app.config的配置文件,写在里面的<connectionStrings n ...

  2. 如何修改 app.config 的配置信息

    如何修改 app.config 的配置信息 收藏 最问这个问题的人有点多,其实 .Net 提供了这样的功能我们可以在 app.config 中 userSettings 节点中保存我们的应用程序设置信 ...

  3. Winform 数据库连接app.config文件配置 数据库连接字符串

    1.添加配置文件 新建一个winform应用程序,类似webfrom下有个web.config,winform下也有个App.config;不过 App.config不是自动生成的需要手动添加,鼠标右 ...

  4. C# App.config 自定义 配置节 报错“配置系统未能初始化” 解决方法

    App.config,结果运行的时候出现了 "配置系统未能初始化" 的错误.找了半天才发现是下面的原因造成的: "如果配置文件中包含configSections元素,则c ...

  5. C# app.config文件配置和修改

    很多时候我们需要对系统的.config文件进度读写操作,例如:系统初始化的参数的更改.系统参数的改变都需要更新到配置文件. 首先我们有必要了解一下app.config.exe.config和vshos ...

  6. Winform数据库连接app.config文件配置

    1.添加配置文件 新建一个winform应用程序,类似webfrom下有个web.config,winform下也有个App.config;不过 App.config不是自动生成的需要手动添加,鼠标右 ...

  7. c# 修改winform中app.config的配置值

    public bool ChangeConfig(string AppKey,string AppValue) { bool result = true; try { XmlDocument xDoc ...

  8. c#Winform程序调用app.config文件配置数据库连接字符串

    你新建winform项目的时候,会有一个app.config的配置文件,写在里面的<connectionStrings name="  " connectionString= ...

  9. App.config:配置系统未能初始化的异常

    如上图所示:App.config文件是这样配置的,在后台代码”ISchedulerFactory scheduler = new StdSchedulerFactory();“中抛出了异常 经网上查资 ...

随机推荐

  1. Spring框架 JdbcTemplate类 @Junit单元测试,可以让方法独立执行 如:@Test

    package cn.zmh.PingCe; import org.junit.Test; import org.springframework.jdbc.core.BeanPropertyRowMa ...

  2. 如何使用KeyChain保存和获取UDID - Flex/AS Programmer

    原文 http://www.cnblogs.com/yssgyw/p/3364370.html 本文是iOS7系列文章第一篇文章,主要介绍使用KeyChain保存和获取APP数据,解决iOS7上获取不 ...

  3. 从SOA到BFV【普元的一份广告文章】

    人类对美好生活的追求是一切技术进步的原动力. 简便.快捷.联结……,这些移动互联的价值让它正成为最贴近消费者的力量.人和设备,设备和设备,人和服务,人和企业,企业和企业都发生了连接.诸如微信.携程.大 ...

  4. android开发之 Wifi的四个类

    android开发之 Wifi的四个类 在Android中对Wifi操作,android本身提供了一些实用的包,在android.net.wifi包以下.简介一下: 大致能够分为四个基本的类ScanR ...

  5. PPT中的图像失真

    现象:Office PowerPoint 保存出来的PPT文件在WPS下播放的时候会出现图像失真的显现. 解决方法:Office PowerPoint打开PPT将里面的图像另存为BMP格式的图像文件, ...

  6. 【自用】OI计划安排表一轮

    网络流√ 上下界最大流√ 线性规划转费用流√ RMQ优化建图√ 单纯形√ 字符串相关 hash√ 扩展KMP 回文自己主动机 数据结构 平衡树 启示式合并 替罪羊树 LCT 树套树 KD-Tree 二 ...

  7. PCA主成分分析Python实现

    作者:拾毅者 出处:http://blog.csdn.net/Dream_angel_Z/article/details/50760130 Github源代码:https://github.com/c ...

  8. ADO.NET EF 4.2 中的查询缓存(避免查询缓存)

    在WinForm系统中遇到了个问题,Form1是查询窗口,根据条件查询出所有数据,双击列表后创建弹出Form2窗口编辑单个记录,但编辑后保存后,在Form2中查询到的还是旧的数据,实际数据库中已经更新 ...

  9. 【源代码】LruCache源代码剖析

    上一篇分析了LinkedHashMap源代码,这个Map集合除了拥有HashMap的大部分特性之外.还拥有链表的特点,即能够保持遍历顺序与插入顺序一致. 另外.当我们将accessOrder设置为tr ...

  10. Android应用程序窗体View的创建过程

    View类是android中非常重要的一个类.view是应用程序界面的直观体现,我们看到的应用程序界面就能够看作是View(视图)组成的. 那么我们应用程序的界面是怎么创建的呢,也就是应用程序的Vie ...