Flask系列教程(9)——上下文

对Flask和Python感兴趣的,可以看下这个超详细的免费视频课程哦:Flask零基础到项目实战

Flask上下文:

Flask项目中有两个上下文,一个是应用上下文(app),另外一个是请求上下文(request)。请求上下文request和应用上下文current_app都是一个全局变量。所有请求都共享的。Flask有特殊的机制可以保证每次请求的数据都是隔离的,即A请求所产生的数据不会影响到B请求。所以可以直接导入request对象,也不会被一些脏数据影响了,并且不需要在每个函数中使用request的时候传入request对象。这两个上下文具体的实现方式和原理可以没必要详细了解。只要了解这两个上下文的四个属性就可以了:

  • request:请求上下文上的对象。这个对象一般用来保存一些请求的变量。比如methodargsform等。
  • session:请求上下文上的对象。这个对象一般用来保存一些会话信息。
  • current_app:返回当前的app。
  • g:应用上下文上的对象。处理请求时用作临时存储的对象。

常用的钩子函数

  • before_first_request:处理第一次请求之前执行。例如以下代码:
@app.before_first_request
def first_request():
    print 'first time request'
  • before_request:在每次请求之前执行。通常可以用这个装饰器来给视图函数增加一些变量。例如以下代码:
@app.before_request
def before_request():
    if not hasattr(g,'user'):
      setattr(g,'user','xxxx')
  • teardown_appcontext:不管是否有异常,注册的函数都会在每次请求之后执行。
@app.teardown_appcontext
def teardown(exc=None):
  if exc is None:
    db.session.commit()
  else:
    db.session.rollback()
    db.session.remove()
  • template_filter:在使用Jinja2模板的时候自定义过滤器。比如可以增加一个upper的过滤器(当然Jinja2已经存在这个过滤器,本示例只是为了演示作用):
@app.template_filter
def upper_filter(s):
    return s.upper()
  • context_processor:上下文处理器。返回的字典中的键可以在模板上下文中使用。例如:
@app.context_processor
def my_context_processor():
    return {'current_user':'xxx'}
  • errorhandler:errorhandler接收状态码,可以自定义返回这种状态码的响应的处理方法。例如:
@app.errorhandler(404)
def page_not_found(error):
    return 'This page does not exist',404

对Flask和Python感兴趣的,可以看下这个超详细的免费视频课程哦:Flask零基础到项目实战

你可能感兴趣的:(Flask系列教程(9)——上下文)