Flask开发:实例化Flask参数与app配置

1. 初始配置参数

对Flask实例进行初始配置的参数,在pycharm中按住Ctrl键的同时点击下面的Flask,可查看默认参数:

app = Flask(__name__)

常用的:

static_folder = 'static',  # 静态文件目录的路径 默认当前项目中的static目录
static_url_path = None,  # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时复用
template_folder = 'templates'  # template模板目录, 默认当前项目中的 templates 目录

不常用的:

static_host = None,  # 远程静态文件所用的Host地址,默认为空
# host_matching是否开启host主机位匹配,是要与static_host一起使用,如果配置了static_host, 则必须赋值为True
# 这里要说明一下,@app.route("/",host="localhost:5000") 就必须要这样写
# host="localhost:5000" 如果主机头不是 localhost:5000 则无法通过当前的路由
host_matching = False,  # 如果不是特别需要的话,慎用,否则所有的route 都需要host=""的参数

subdomain_matching = False,  # 理论上来说是用来限制SERVER_NAME子域名的,但是目前还没有感觉出来区别在哪里
instance_path = None,  # 指向另一个Flask实例的路径
instance_relative_config = False  # 是否加载另一个实例的配置
root_path = None  # 主模块所在的目录的绝对路径,默认项目目录

具体可参考:Flask应用程序对象

2. app配置参数

app.config()

在pycharm中按住Ctrl键的同时点击上面的config进入Flask源码部分,如下所示:

self.config = self.make_config(instance_relative_config)

再按住Ctrl键的同时点击上面的make_config,在下面找到default_config,重复上面的操作
在这里插入图片描述
可以在里面看到实例化app的默认配置,下面是部分参数的含义:

{
    'DEBUG': False,  # 是否开启Debug模式
    'TESTING': False,  # 是否开启测试模式
    'PROPAGATE_EXCEPTIONS': None,  # 异常传播(是否在控制台打印LOG) 当Debug或者testing开启后,自动为True
    'PRESERVE_CONTEXT_ON_EXCEPTION': None,  # 一两句话说不清楚,一般不用它
    'SECRET_KEY': None,  # 之前遇到过,在启用Session的时候,一定要有它
    'PERMANENT_SESSION_LIFETIME': 31,  # days , Session的生命周期(天)默认31天
    'USE_X_SENDFILE': False,  # 是否弃用 x_sendfile
    'LOGGER_NAME': None,  # 日志记录器的名称
    'LOGGER_HANDLER_POLICY': 'always',
    'SERVER_NAME': None,  # 服务访问域名
    'APPLICATION_ROOT': None,  # 项目的完整路径
    'SESSION_COOKIE_NAME': 'session',  # 在cookies中存放session加密字符串的名字
    'SESSION_COOKIE_DOMAIN': None,  # 在哪个域名下会产生session记录在cookies中
    'SESSION_COOKIE_PATH': None,  # cookies的路径
    'SESSION_COOKIE_HTTPONLY': True,  # 控制 cookie 是否应被设置 httponly 的标志,
    'SESSION_COOKIE_SECURE': False,  # 控制 cookie 是否应被设置安全标志
    'SESSION_REFRESH_EACH_REQUEST': True,  # 这个标志控制永久会话如何刷新
    'MAX_CONTENT_LENGTH': None,  # 如果设置为字节数, Flask 会拒绝内容长度大于此值的请求进入,并返回一个 413 状态码
    'SEND_FILE_MAX_AGE_DEFAULT': 12,  # hours 默认缓存控制的最大期限
    'TRAP_BAD_REQUEST_ERRORS': False,
    # 如果这个值被设置为 True ,Flask不会执行 HTTP 异常的错误处理,而是像对待其它异常一样,
    # 通过异常栈让它冒泡地抛出。这对于需要找出 HTTP 异常源头的可怕调试情形是有用的。
    'TRAP_HTTP_EXCEPTIONS': False,
    # Werkzeug 处理请求中的特定数据的内部数据结构会抛出同样也是“错误的请求”异常的特殊的 key errors 。
    # 同样地,为了保持一致,许多操作可以显式地抛出 BadRequest 异常。
    # 因为在调试中,你希望准确地找出异常的原因,这个设置用于在这些情形下调试。
    # 如果这个值被设置为 True ,你只会得到常规的回溯。
    'EXPLAIN_TEMPLATE_LOADING': False,
    'PREFERRED_URL_SCHEME': 'http',  # 生成URL的时候如果没有可用的 URL 模式话将使用这个值
    'JSON_AS_ASCII': True,
    # 默认情况下 Flask 使用 ascii 编码来序列化对象。如果这个值被设置为 False ,
    # Flask不会将其编码为 ASCII,并且按原样输出,返回它的 unicode 字符串。
    # 比如 jsonfiy 会自动地采用 utf-8 来编码它然后才进行传输。
    'JSON_SORT_KEYS': True,
    #默认情况下 Flask 按照 JSON 对象的键的顺序来序来序列化它。
    # 这样做是为了确保键的顺序不会受到字典的哈希种子的影响,从而返回的值每次都是一致的,不会造成无用的额外 HTTP 缓存。
    # 你可以通过修改这个配置的值来覆盖默认的操作。但这是不被推荐的做法因为这个默认的行为可能会给你在性能的代价上带来改善。
    'JSONIFY_PRETTYPRINT_REGULAR': True,
    'JSONIFY_MIMETYPE': 'application/json',
    'TEMPLATES_AUTO_RELOAD': None,
}

以上这些Key,都可以被改写,当然他们也都是有默认值存在的,如果没有特殊情况,不要改写它的默认值

修改配置的方式有两种:

1.直接对app.config进行修改

app.config["DEBUG"] = True

2.使用类的方式导入

首先要有一个settings.py的文件

class FlaskSetting:
    DEBUG = True
    SECRET_KEY = "DragonFire"

然后我们在Flask的启动文件中就可以这么写

from flask import Flask


app = Flask(__name__)  # type:Flask
app.config.from_object("settings.FlaskSetting")

这叫做类导入配置,适用于比较大型的web应用开发

具体可参考:Flask应用程序对象

Flask一个轻量级的Python Web应用框架,它非常适合快速构建小型到中型的应用,包括图书管理系统。下面是一个简单的Flask图书管理系统的概述: 1. **安装Flask**:首先需要安装Flask库,可以使用pip命令 `pip install flask`。 2. **创建项目结构**:设置基本目录结构,比如`app.py`作为主程序文件,以及`templates`用于存放HTML模板,`static`用于静态文件如CSS、JS等。 3. **初始化Flask应用**:在`app.py`中导入Flask,创建并配置应用实例,例如: ```python from flask import Flask, render_template, request app = Flask(__name__) ``` 4. **路由设计**:定义处理HTTP请求的函数,例如展示主页,添加图书,删除图书等。例如,展示图书列表的路由可以是`/books`: ```python @app.route('/') def index(): # 这里假设有一个从数据库获取数据的函数get_books() books = get_books() return render_template('index.html', books=books) ``` 5. **视图函数**:通过`render_template`渲染HTML模板,并将数据传递给模板。例如,`templates/index.html`可能会包含表格显示图书信息。 6. **表单处理**:如果涉及到用户输入,可以使用Flask-WTF扩展处理表单提交,例如添加图书的表单: ```python from flask_wtf import FlaskForm class BookForm(FlaskForm): title = StringField('Title') author = StringField('Author') @app.route('/add_book', methods=['GET', 'POST']) def add_book(): form = BookForm() if form.validate_on_submit(): # 添加新书到数据库 add_new_book(form.data) flash('Book added successfully.') return render_template('add_book.html', form=form) ``` 7. **连接数据库**:为了持久化存储图书数据,你需要一个数据库后端,如SQLite、MySQL或PostgreSQL,Flask SQLAlchemy是一个不错的选择,它可以方便地与多种数据库集成。 8. **部署**:将应用部署到服务器,如使用Gunicorn和uWSGI,或者直接通过Flask的内置服务器运行测试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值