本篇文章给大家分享的是有关Flask框架中有哪些常见的装饰器,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
@app.before_request
def before(*args,**kwargs):
print('请求之前')
'''
如果允许通过访问,可以return None
该装饰器装饰的函数如果有return其他内容则直接结束访问,
效果有点类似django的process_reqeust中间件方法。
比如通过这个装饰器写登陆验证,判断其是否有session,没有则不允许访问,有则继续访问
然后通过request.path判断访问的函数,如果是登陆(白名单)则通过。
request.url 是完整的url
request.path是域名后面的url正则
'''
if request.path == '/login':
return None
user = session.get('user_info')
if user:
return None
return redirect('/login')
类似process_response
@app.after_request
def after(response):
#效果和process_response是一样的,必须有返回值,没有则报错。
print('我走了')
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
。
自定义错误页面:
@app.error_handlers(404)
def error_404(arg):
'''自定义错误页面,根据状态码定制'''
return "404错误啦"
模板中定制方法:
前端直接调用后端函数的装饰器:
@app.template_global()
def xx(a1,a2):
return a1+a2
'''
这个装饰器的作用就是,可以在前端直接通过{{ xx(1,2)}}来调用后端的这个函数。
'''
相当于filter的装饰器
@app.template_filter()
def db(a1,a2,a3):
return a1+a2+a3
'''
效果和django的Filter相似,前端渲染的时候需要注意写法
{{ 1|db(2,3)}} 1是第一个参数,后面是2,3参数。
'''
第一次来请求操作的装饰器:
@app.before_first_request
def first(*args,**kwargs):
pass
'''
只有第一次请求时候才执行的函数装饰器
'''
Flask的中间件一般感觉用处不大,不如装饰器方便
以上就是Flask框架中有哪些常见的装饰器,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注天达云行业资讯频道。