flask 杂记

参考资料:http://python.jobbole.com/84003/  https://flask-cn.readthedocs.io/en/latest/tutorial/

加载配置:

app = Flask(__name__)
app.config.from_object(__name__)

from_object() 会识别给出的对象(如果是一个字符串,它 会自动导入这个模块),然后查找所有已定义的大写变量。在我们这个例子里,配置 在几行代码前。你也可以把它移动到一个单独的文件中。

app.config.from_envvar('FLASKR_SETTINGS', silent=True)

silent参数是为了告诉Flask不要报错,即使没有设置 环境变量

 ===================

从 _future_ 中的import内容要在所有import的最前面

from __future__ import with_statement
from contextlib import closing

===================

from flask import g

@app.before_request def before_request(): g.db
= connect_db() @app.after_request def after_request(response): g.db.close() return response

用 before_request() 装饰的函数在每次请求之前 被调用,它没有参数。用 after_request() 装饰的函数是在每 次请求结束后被调用,而且它需要传入response。这类函数必须返回同一个response 对象或者一个不同的response对象

我们把当前的数据库连接保存在一个特殊的对象 g 里面,这个对象 flask已经为我们提供了。这个对象只能用来为一个请求保存信息,每一个函数都可以 访问这个对象。不要用其他的对象来保存信息,因为在多线程的环境下会无法工作。 g 对象是一个特殊的对象,它会在后台做一些魔术来确保它能够跟我 们预想的一样执行

===========================

 我们的模版将使用 Jinja2 的格式,而且默 认是打开自动转义的。这也就是说,除非我们在代码中用 Markup 标记一个值,或者在模版中用 |safe 过滤器,否则Jinja2会将一些特殊字符, 如 < 或 > 用XML格式来转义

========================报错邮件

ADMINS = ['yourname@example.com']
if not app.debug:
    import logging
    from logging.handlers import SMTPHandler
    mail_handler = SMTPHandler('127.0.0.1',
                               'server-error@example.com',
                               ADMINS, 'YourApplication Failed')
    mail_handler.setLevel(logging.ERROR)
    app.logger.addHandler(mail_handler)

我们创建了一个新的类 SMTPHandler ,他 将通过 127.0.0.1 的邮件服务器向所有的 ADMINS 用户发送标题为“YourApplication Failed” 邮件,并且将发件地址配置为 server-error@example.com 。此外,我们还提供了对 需要证书的邮件服务器的支持

==================配置

在Flask中,有一个现成的保存、载入的对象,就是 Flask 类中的 config 对象。在这个对象中Flask不仅存放自己的配置,还存放拓展插件的配置,而且也存放你对于自己应用的自己的配置。

=================

怎么拿到应用程序的当前配置呢?使用 current_app:

from flask import current_app, Blueprint, render_template
admin = Blueprint('admin', __name__, url_prefix='/admin')

@admin.route('/')
def index():
    return render_template(current_app.config['INDEX_TEMPLATE'])

 =================日志

import logging
from logging.handlers import SysLogHandler
syslog_handler = SysLogHandler()
syslog_handler.setLevel(logging.WARNING)
app.logger.addHandler(syslog_handler)

 ==============

常见的request客户端变量

request.json 获取从客户端从请求body获取的json字符串

Request.files 获取从客户端请求过来的文件

request.data:获取的是非表单以post,提交的数据

request.form:获取的表单以post方式提交的数据

request.args:获取的是问号后面的查询参数(是个字典MultiDict也是字典,字典的形式有很多,但是都是key:value的方式)

request.method:获取的请求方式

request.url:获取的是请求的地址

request.files:获取的是input标签中type类型为file的文件

===============

在app.config对象中保存了flask的默认配置以及我们项目中写入的配置变量

=============

自定义参数类型(自定义转换器)

背景:如果系统提供的int,float等参数类型满足不了需求的时候,我们需要自定义

之所以int,float,path可以接受不同的数据类型,是因为,系统已经提供好了对应的转换器了

自定义转换器格式:

1、定义类,继承自BaseConverter

2、重写init方法,去接收两个参数

3、初始化父类成员变量,还有子类自己的规则

4、将转换器类,添加到系统默认的转换器列表中

========================

返回响应

1、直接返回响应体数据

return ‘字符串’

2、直接返回响应体数据、状态码

return ‘字符串’,'状态码'

3、直接返回响应体数据、状态码、响应头信息

return '字符串',状态码,{'key':'value'}

通过jsonify返回json数据

格式:jsonify(dict)

简化格式:jsonify(key=value,key2=value2)

===================

1、从配置类(对象)中加载

app.config.from_object(obj)

2、从配置文件中加载

app.config.from_pyfile(file)

file可以是文件,我们可以写txt格式,ini格式(有颜色提示)等。直接将文件的路径填写进file的位置即可

3、从环境变量中加载(做了解)

app.config.from_envvar(环境变量)

===================

 

常见的请求钩子有四种:

1.before_first_request:在处理第一个请求前执行

里面适合做初始化操作,比如io文件读写

2.before_request:在每次请求前执行,在该装饰函数中,一旦return,视图函数不再执行

适合对请求参数做校验,访问统计

3.after_request:如果没有抛出错误,在每次请求后执行

接受一个参数:视图函数作出的响应

视图函数执行之后,返回该方法,适合对返回值做统一处理,比如返回统一的json数据格式

接收的参数是将视图函数的返回值打包之后的响应体信息。

在此函数中可以对响应值,在返回之前做最后一步处理,再返回

4.teardown_request:不管是否有异常,注册的函数都会在每次请求之后执行

接受一个参数:用来接收错误信息

请求销毁之后执行,执行该方法,适合做异常信息统计。在工作中,我们可以将这些异常信息放进文件中,方便我们隔一段时间进行查看。

=================

 flask提供了jsonify函数供用户处理返回的序列化json数据,而python自带的json库中也有dumps方法可以序列化json对象

============

 

使用flask中提供好的方法,快速将前端的json数据转成dict

传统方法,json转字典

1/json_data = request.data

2/dict_data = json.loads(json_data)

快速将json转字典的方法:

dict_data = request.json

或者dict_data = request.get_json()

===================

 使用当前时间作为默认值:

timestamp = db.Column (db . DateTime , default=datetime.now, index=True)

timestamp 字段的默认值是 datetime.now 而不是 datetime.now()。

=====给flask配置日志

import logging
from logging import StreamHandler
file_handler = StreamHandler()
file_handler.setLevel(logging.WARNING)
app.logger.addHandler(file_handler)

 

==========

import threading

lock = threading.Lock()
app = Flask(__name__)
app.config["call_index"] = 0

@app.route("/obj_detect", methods=['POST'])
def obj_detect():
    with lock:
        current_app.config['call_index'] = current_app.config['call_index'] + 1
        index = current_app.config.get('call_index')

 

posted on 2019-06-04 19:26  我和你并没有不同  阅读(193)  评论(0编辑  收藏  举报