(四)Flask——配置详解

一、配置:

Flask中的配置文件是一个flask.config.Config对象(继承字典)。后续会剖析源码瞅瞅。

基本方法:

  1. 直接设置配置项——可以直接在应用程序中设置配置项,而不使用配置文件或环境变量。例如,在应用程序中使用以下代码设置配置项:
from flask import Flask

app = Flask(__name__)
app.config['DEBUG'] = True
app.config['SECRET_KEY'] = 'GuHanZheIsCool'

开头讲了Config对象继承字典,所以还可以使用app.config.update(…)。

  1. 使用配置文件——将所有的配置项写入一个配置文件中,并通过app.config.from_pyfile()方法导入。例如,在应用程序的根目录下创建一个名为config.py的配置文件,然后使用以下代码导入配置:
from flask import Flask

app = Flask(__name__)
app.config.from_pyfile('config.py')

config.py配置文件示例:

DEBUG = True
SECRET_KEY = 'GuHanZheIsCool'
DATABASE_URI = 'mysql://user:password@localhost/demodatabase'

  1. 使用环境变量——将配置项以环境变量的形式设置,并通过app.config.from_envvar()方法导入。例如,在终端或命令行中设置环境变量FLASK_CONFIG为配置文件的路径,然后使用以下代码导入配置:
from flask import Flask

app = Flask(__name__)
app.config.from_envvar('FLASK_CONFIG')

  • 但是,在真实开发时,我们会面临一个问题——一般一个项目会有测试、开发和生产三大环境,这三大环境下的配置会各有不同,比如不同的数据库、不同的cookie配置等。所以Flask为我们提供了一个非常适合开发的解决方法。如下:

真实开发使用的方法:

  • 使用类配置——创建一个配置类,将所有的配置项作为类的属性,并通过app.config.from_object()方法导入。例如,创建一个名为Config的配置类,然后使用以下代码导入配置:
from flask import Flask

app = Flask(__name__)
# 配置文件              导入settings.py文件里的DevelopmentConfig类对象里的所有配置项
app.config.from_object("settings.DevelopmentConfig")


@app.route('/index', methods=['GET', 'POST'])
def index():
    return 'hello world'


if __name__ == '__main__':
    app.run('localhost', 4000)
    
  • 同级目录下的settings.py文件:
import os


class BaseConfig(object):
    """Base Configuration"""

    # Root path of project
    PROJECT_PATH = os.path.abspath(os.path.join(os.path.dirname(__file__), ".."))

    DEBUG = True
    SECRET_KEY = 'GuHanZheIsCool'
    
    # Redis configuration
    REDIS_URL = os.environ.get("REDIS_URL")
    

    # File setting
    UPLOAD_FILE_FOLDER = "./project/data"    # 上传文件存储路径
    FILE_MAX_SIZE = 30 * 1024 * 1024


class ProductionConfig(BaseConfig):
    """Production Configuration"""
    DEBUG = False


class DevelopmentConfig(BaseConfig):
    """Development Configuration"""
    pass


class TestingConfig(BaseConfig):
    """Testing Configuration"""
    pass

在 Flask 中,配置文件通常是一个 Python 模块,其中包含各种 Flask 配置选项的值。以下是 Flask 配置文件中可设置的一些基本选项:

  1. DEBUG: 是否启用调试模式,如果设置为 True,可以在网页中看到详细的错误信息和调试信息。同时会使我们的项目自动重新加载——在调试模式下,如果应用程序的代码发生更改,服务器会自动重新加载应用程序,以便立即反映代码的修改,而无需手动重启服务器。

  2. SECRET_KEY: secret key 是 Flask 中加密cookie所需的密钥,它是加密算法的“种子”,确保加密的安全性。需要保证每个应用程序都有一个固定的密钥,建议使用生成随机密钥的工具生成一个。

  3. SQLALCHEMY_DATABASE_URI: 指定 SQLite、MySQL 或 PostgreSQL 数据库的 URI,表示要连接到的数据库。

  4. SQLALCHEMY_TRACK_MODIFICATIONS: 是否启用 SQLAlchemy 的跟踪修改。默认值是 False。要禁用跟踪修改,可以将其值设置为 False

  5. CACHE_TYPE: 缓存类型,支持 SimpleCache、RedisCache 和 MemcachedCache。

  6. CACHE_DEFAULT_TIMEOUT: 默认缓存时间,单位为秒。

  7. SESSION_TYPE: session类型,支持 Redis、Memcached、Filesystem 等。

  8. SESSION_COOKIE_NAME: session cookie 名称。

  9. SESSION_COOKIE_SECURE: 是否使用安全 cookies,在使用 HTTPS 协议时可以设置为 True

  10. SESSION_PERMANENT: cookie 是否永久有效。

  11. SESSION_FILE_DIR: 文件存储 session 时的保存路径。

  12. UPLOAD_FOLDER: 文件上传时的保存路径。

上面只是Flask 配置文件中的一些基本选项,详细需要查看 Flask 官方文档,了解更多有关配置选项的信息。

以下是Flask官方文档中关于配置项的一些开发中常需查询的链接:

  • Flask配置文档:https://flask.palletsprojects.com/en/2.0.x/config/
  • Flask配置字典的说明:https://flask.palletsprojects.com/en/2.0.x/api/#configuration
  • Flask开发服务器配置选项:https://flask.palletsprojects.com/en/2.0.x/server/
  • Flask应用程序的配置模式:https://flask.palletsprojects.com/en/2.0.x/patterns/appfactories/
  • Flask-WTF扩展的配置选项:https://flask-wtf.readthedocs.io/en/0.15.x/config.html

在这些文档中,有Flask配置项的详细说明和示例。提供了关于如何设置和使用配置项的详细说明,以及每个配置项的作用和默认值。

你可能感兴趣的:(Flask框架从入门到实战,flask,python,后端,配置项,Config对象)