---恢复内容开始---
app的配置
Flask的配置就是在app.config中添加一个键值对,但是存进去的键必须是config中应该存在的,如果不存在的话,会默认无用,就放在那
使用方法:
1 from flask import Flask 2 3 app01 = Flask(__name__) 4 app01.config['DEBUG'] = True
app01.config['DEBUG'] = True就是传说中的debug模式(调试模式),实现的功能是,只要代码发生变动,会自动重启Flask程序
下面是config中的key:
1 { 2 'DEBUG': False, # 是否开启Debug模式 3 'TESTING': False, # 是否开启测试模式 4 'PROPAGATE_EXCEPTIONS': None, # 异常传播(是否在控制台打印LOG) 当Debug或者testing开启后,自动为True 5 'PRESERVE_CONTEXT_ON_EXCEPTION': None, # 一两句话说不清楚,一般不用它 6 'SECRET_KEY': None, # 之前遇到过,在启用Session的时候,一定要有它 7 'PERMANENT_SESSION_LIFETIME': 31, # days , Session的生命周期(天)默认31天 8 'USE_X_SENDFILE': False, # 是否弃用 x_sendfile 9 'LOGGER_NAME': None, # 日志记录器的名称 10 'LOGGER_HANDLER_POLICY': 'always', 11 'SERVER_NAME': None, # 服务访问域名 12 'APPLICATION_ROOT': None, # 项目的完整路径 13 'SESSION_COOKIE_NAME': 'session', # 在cookies中存放session加密字符串的名字 14 'SESSION_COOKIE_DOMAIN': None, # 在哪个域名下会产生session记录在cookies中 15 'SESSION_COOKIE_PATH': None, # cookies的路径 16 'SESSION_COOKIE_HTTPONLY': True, # 控制 cookie 是否应被设置 httponly 的标志, 17 'SESSION_COOKIE_SECURE': False, # 控制 cookie 是否应被设置安全标志 18 'SESSION_REFRESH_EACH_REQUEST': True, # 这个标志控制永久会话如何刷新 19 'MAX_CONTENT_LENGTH': None, # 如果设置为字节数, Flask 会拒绝内容长度大于此值的请求进入,并返回一个 413 状态码 20 'SEND_FILE_MAX_AGE_DEFAULT': 12, # hours 默认缓存控制的最大期限 21 'TRAP_BAD_REQUEST_ERRORS': False, 22 # 如果这个值被设置为 True ,Flask不会执行 HTTP 异常的错误处理,而是像对待其它异常一样, 23 # 通过异常栈让它冒泡地抛出。这对于需要找出 HTTP 异常源头的可怕调试情形是有用的。 24 'TRAP_HTTP_EXCEPTIONS': False, 25 # Werkzeug 处理请求中的特定数据的内部数据结构会抛出同样也是“错误的请求”异常的特殊的 key errors 。 26 # 同样地,为了保持一致,许多操作可以显式地抛出 BadRequest 异常。 27 # 因为在调试中,你希望准确地找出异常的原因,这个设置用于在这些情形下调试。 28 # 如果这个值被设置为 True ,你只会得到常规的回溯。 29 'EXPLAIN_TEMPLATE_LOADING': False, 30 'PREFERRED_URL_SCHEME': 'http', # 生成URL的时候如果没有可用的 URL 模式话将使用这个值 31 'JSON_AS_ASCII': True, 32 # 默认情况下 Flask 使用 ascii 编码来序列化对象。如果这个值被设置为 False , 33 # Flask不会将其编码为 ASCII,并且按原样输出,返回它的 unicode 字符串。 34 # 比如 jsonfiy 会自动地采用 utf-8 来编码它然后才进行传输。 35 'JSON_SORT_KEYS': True, 36 #默认情况下 Flask 按照 JSON 对象的键的顺序来序来序列化它。 37 # 这样做是为了确保键的顺序不会受到字典的哈希种子的影响,从而返回的值每次都是一致的,不会造成无用的额外 HTTP 缓存。 38 # 你可以通过修改这个配置的值来覆盖默认的操作。但这是不被推荐的做法因为这个默认的行为可能会给你在性能的代价上带来改善。 39 'JSONIFY_PRETTYPRINT_REGULAR': True, 40 'JSONIFY_MIMETYPE': 'application/json', 41 'TEMPLATES_AUTO_RELOAD': None, 42 }
以上这些key都可以被改写,他们都是有默认值存在的,如果没有特殊情况,不要改写他们的值
上面已经看到了config的配置key,那么我们怎么对这些配置进行修改呢,现在有两种方式
第一种, 直接对app.config进行修改
app01.config['DEBUG'] = True
第二种, 使用类的方式导入
首先我们建立一个settings.py文件
1 class FlaskSetting: 2 DEBUGE = True 3 SECRET_KEY = "DrangonFire"
然后在flask的启动文件中
from flask import Flask from flask02.settings import FlaskSetting app01 = Flask(__name__) app01.config.from_object("FlaskSetting")
实例化flask的参数
1 static_folder = 'static', # 静态文件目录的路径 默认当前项目中的static目录 2 static_host = None, # 远程静态文件所用的Host地址,默认为空 3 static_url_path = None, # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时复用 4 # host_matching是否开启host主机位匹配,是要与static_host一起使用,如果配置了static_host, 则必须赋值为True 5 # 这里要说明一下,@app.route("/",host="localhost:5000") 就必须要这样写 6 # host="localhost:5000" 如果主机头不是 localhost:5000 则无法通过当前的路由 7 host_matching = False, # 如果不是特别需要的话,慎用,否则所有的route 都需要host=""的参数 8 subdomain_matching = False, # 理论上来说是用来限制SERVER_NAME子域名的,但是目前还没有感觉出来区别在哪里 9 template_folder = 'templates' # template模板目录, 默认当前项目中的 templates 目录 10 instance_path = None, # 指向另一个Flask实例的路径 11 instance_relative_config = False # 是否加载另一个实例的配置 12 root_path = None # 主模块所在的目录的绝对路径,默认项目目录
常用参数如下
static_folder = 'static', # 静态文件目录的路径 默认当前项目中的static目录 static_url_path = None, # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时复用 template_folder = 'templates' # template模板目录, 默认当前项目中的 templates 目录
---恢复内容结束---
浙公网安备 33010602011771号