Flask的各种装饰器

效果类似django的process_request的装饰器

 1 @app.before_request
 2 def before(*args,**kwargs):
 3     print('请求之前')
 4     '''
 5     如果允许通过访问,可以return None
 6     该装饰器装饰的函数如果有return其他内容则直接结束访问,
 7     效果有点类似django的process_reqeust中间件方法。
 8     比如通过这个装饰器写登陆验证,判断其是否有session,没有则不允许访问,有则继续访问
 9     然后通过request.path判断访问的函数,如果是登陆(白名单)则通过。
10     request.url 是完整的url
11     request.path是域名后面的url正则
12     '''
13     if request.path == '/login':
14         return None
15     user = session.get('user_info')
16     if user:
17         return None
18     return redirect('/login')

类似process_response

1 @app.after_request
2 def after(response):
3     #效果和process_response是一样的,必须有返回值,没有则报错。
4     print('我走了')
5     return response
flask中间件装饰器执行顺序。
如果多个app.before_request和app.after_request,
那么执行顺序也和django类似,
app.before_request是按照从上而下执行(文件的上下),app.after_request是自下而上执行。
如果在app.before_request中return了其他内容,请求被拦截,那么不会执行视图函数,
直接从最后一个app.after_reqeust倒着开始执行所有after_request。
 
自定义错误页面:
1 @app.error_handlers(404)
2 def error_404(arg):
3     '''自定义错误页面,根据状态码定制'''
4     return "404错误啦"
模板中定制方法:
前端直接调用后端函数的装饰器:
1 @app.template_global()
2 def xx(a1,a2):
3     return a1+a2
4 '''
5 这个装饰器的作用就是,可以在前端直接通过{{ xx(1,2)}}来调用后端的这个函数。
6 '''

相当于filter的装饰器

1 @app.template_filter()
2 def db(a1,a2,a3):
3     return a1+a2+a3
4 '''
5 效果和django的Filter相似,前端渲染的时候需要注意写法
6 {{ 1|db(2,3)}} 1是第一个参数,后面是2,3参数。
7 '''
第一次来请求操作的装饰器:
1 @app.before_first_request
2 def first(*args,**kwargs):
3     pass
4 '''
5 只有第一次请求时候才执行的函数装饰器
6 '''

Flask的中间件一般感觉用处不大,不如装饰器方便

通过重新复制app.wsgi_app,
重写这个类的__call__方法,如上图,只是增加了两个打印,效果同process_request,process_response

 

posted @ 2018-04-18 22:42  铠甲巨人  阅读(5810)  评论(1编辑  收藏  举报