目录css
首先展现一下:html
from flask import Flask app = Flask(__name__) # type:Flask app.config["DEBUG"] = True#app.debug=True #同场面的config配置,这是封装后的样子
这句 app.config["DEBUG"] = True 能够实现的功能可刺激了前端
代码只要发生改动,自动重启Flask程序(app.run)python
在控制台打印的信息很是全面jquery
以上两个功能就是传说中的 DEBUG 模式(调试模式)web
Flask的配置就是在 app.config 中添加一个键值对,可是你存进去的键必须是config中应该存在的,若是再也不存在的话,它会默认无用,就这么放着json
咱们经过print(app.default_config())便可得到全部的config配置参数flask
这些Key,均可以被改写,固然他们也都是有默认值存在的,若是没有特殊状况,不要改写它的默认值后端
{ '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, }
app.config["DEBUG"] = True
经过第二种类导入模式,方便配置文件切换使用,节约开发成本缓存
首先要建立一个配置文件:settings.py
import hashlib #这个类是调试的类 class DebugSetting(object): DEBUG = True SECRET_KEY = hashlib.md5(b"12345!@#${}%^&*()_6789").hexdigest() SESSION_COOKIE_NAME = "I am just Session" SESSION_TYPE = 'Redis' # SESSION_REDIS = Redis() #这个是生成测试的类 class TestingSetting(object): TESTING = True SECRET_KEY = "!@#$%^&*()" SESSION_COOKIE_NAME = "I want Fuck You!"
而后咱们在Flask的启动文件中就能够这么写
from flask import Flaskimport settings app = Flask(__name__) # type:Flask app.config.from_object("settings.DebugSetting") #app.config.from_object("settings.TestingSetting")
这是针对一个已经实例化的app进行的配置
那么在Flask实例化的时候,传递的参数是什么鬼呢?
#Flask实例化参数传递app = Flask(__name__,template_folder="templates",static_folder="statics",static_url_path="/statics")参数解释:模本文件存放的目录:templates静态文件存放的目录:statics静态文件 的url访问路径:/statics前端示例: <img src="/statics/1.jpg" alt="">
其实能够理解为对Flask实例进行的初始配置,这里面的参数是很是好理解,注意关键字
static_folder = 'static', # 静态文件目录的路径 默认当前项目中的static目录 static_host = None, # 远程静态文件所用的Host地址,默认为空 static_url_path = None, # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时复用 # 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子域名的,可是目前尚未感受出来区别在哪里 template_folder = 'templates' # template模板目录, 默认当前项目中的 templates 目录 instance_path = None, # 指向另外一个Flask实例的路径 instance_relative_config = False # 是否加载另外一个实例的配置 root_path = None # 主模块所在的目录的绝对路径,默认项目目录
这里面,咱们经常使用的参数有
static_folder = 'static', # 静态文件目录的路径 默认当前项目中的static目录 static_url_path = None, # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时复用 template_folder = 'templates' # template模板目录, 默认当前项目中的 templates 目录
后端代码:
from flask import Flask, render_template app = Flask(__name__, static_folder="statics", static_url_path="/static") app.debug = True # 配置静态文件 @app.route("/index", methods=["POST", "GET"]) def index(): return render_template("index.html") if __name__ == '__main__': app.run()
前端HTML文件:
... <body> <h1>静态文件测试</h1> <img src="/static/1.jpg" alt=""> <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.js"></script> <script></script> </body> </html>
静态文件图例:
web访问: