Flask - 基本使用与配置

简介

Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后触发Flask框架,开发人员基于Flask框架提供的功能对请求进行相应的处理,并返回给用户,如果要返回给用户复杂的内容时,需要借助jinja2模板来实现对模板的处理,即:将模板和数据进行渲染,将渲染后的字符串返回给用户浏览器。

“微”(micro) 并不表示你需要把整个 Web 应用塞进单个 Python 文件(虽然确实可以 ),也不意味着 Flask 在功能上有所欠缺。微框架中的“微”意味着 Flask 旨在保持核心简单而易于扩展。Flask 不会替你做出太多决策——比如使用何种数据库。而那些 Flask 所选择的——比如使用何种模板引擎——则很容易替换。除此之外的一切都由可由你掌握。如此,Flask 可以与您珠联璧合。

默认情况下,Flask 不包含数据库抽象层、表单验证,或是其它任何已有多种库可以胜任的功能。然而,Flask 支持用扩展来给应用添加这些功能,如同是 Flask 本身实现的一样。众多的扩展提供了数据库集成、表单验证、上传处理、各种各样的开放认证技术等功能。Flask 也许是“微小”的,但它已准备好在需求繁杂的生产环境中投入使用。

安装

1 pip3 install flask

示例

1 from flask import Flask
2 app = Flask(__name__)
3   
4 @app.route('/')
5 def hello_world():
6     return 'Hello World!'
7   
8 if __name__ == '__main__':
9     app.run()

配置

flask中的配置文件是一个flask.config.Config对象(继承字典)

配置方法

 1 方式一:
 2     app.config['DEBUG'] = True
 3   
 4     PS: 由于Config对象本质上是字典,所以还可以使用app.config.update(...)
 5   
 6 方式二:
 7     app.config.from_pyfile("python文件名称")
 8         如:
 9             settings.py
10                 DEBUG = True
11   
12             app.config.from_pyfile("settings.py")
13   
14     app.config.from_envvar("环境变量名称")
15         环境变量的值为python文件名称名称,内部调用from_pyfile方法
16   
17   
18     app.config.from_json("json文件名称")
19         JSON文件名称,必须是json格式,因为内部会执行json.loads
20   
21     app.config.from_mapping({'DEBUG':True})
22         字典格式
23   
24     app.config.from_object("python类或类的路径")
25   
26         app.config.from_object('pro_flask.settings.TestingConfig')
27   
28         settings.py
29   
30             class Config(object):
31                 DEBUG = False
32                 TESTING = False
33                 DATABASE_URI = 'sqlite://:memory:'
34   
35             class ProductionConfig(Config):
36                 DATABASE_URI = 'mysql://user@localhost/foo'
37   
38             class DevelopmentConfig(Config):
39                 DEBUG = True
40   
41             class TestingConfig(Config):
42                 TESTING = True
43   
44         PS: 从sys.path中已经存在路径开始写
45       
46   
47     PS: settings.py文件默认路径要放在程序root_path目录,如果instance_relative_config为True,则就是instance_path目录

默认配置参数

 1 {
 2         'DEBUG':                                get_debug_flag(default=False),  是否开启Debug模式
 3         'TESTING':                              False,                          是否开启测试模式
 4         'PROPAGATE_EXCEPTIONS':                 None,                         
 5         'PRESERVE_CONTEXT_ON_EXCEPTION':        None,
 6         'SECRET_KEY':                           None,
 7         'PERMANENT_SESSION_LIFETIME':           timedelta(days=31),
 8         'USE_X_SENDFILE':                       False,
 9         'LOGGER_NAME':                          None,
10         'LOGGER_HANDLER_POLICY':               'always',
11         'SERVER_NAME':                          None,
12         'APPLICATION_ROOT':                     None,
13         'SESSION_COOKIE_NAME':                  'session',
14         'SESSION_COOKIE_DOMAIN':                None,
15         'SESSION_COOKIE_PATH':                  None,
16         'SESSION_COOKIE_HTTPONLY':              True,
17         'SESSION_COOKIE_SECURE':                False,
18         'SESSION_REFRESH_EACH_REQUEST':         True,
19         'MAX_CONTENT_LENGTH':                   None,
20         'SEND_FILE_MAX_AGE_DEFAULT':            timedelta(hours=12),
21         'TRAP_BAD_REQUEST_ERRORS':              False,
22         'TRAP_HTTP_EXCEPTIONS':                 False,
23         'EXPLAIN_TEMPLATE_LOADING':             False,
24         'PREFERRED_URL_SCHEME':                 'http',
25         'JSON_AS_ASCII':                        True,
26         'JSON_SORT_KEYS':                       True,
27         'JSONIFY_PRETTYPRINT_REGULAR':          True,
28         'JSONIFY_MIMETYPE':                     'application/json',
29         'TEMPLATES_AUTO_RELOAD':                None,
30     }

猜你喜欢

转载自www.cnblogs.com/zhaohuhu/p/9218127.html