zoukankan      html  css  js  c++  java
  • flask的请求扩展

    flask的请求扩展

    flask里面的请求扩展相当于django中的中间件

    #flask里面的请求扩展相当于django中的中间件
    from  flask import Flask,request
     
    app  = Flask(__name__)
     
    @app.before_request
    def before1():
        print("我是befor1")
        return "ok"
     
    @app.before_request
    def before2():
        print("我是befor2")
     
     
    @app.after_request
    def after1(response):
        print("响应后的参数",response)
        print("我是after1")
        return response
     
    @app.after_request
    def after2(response):
     
        print("我是after2")
        return response
     
    @app.before_first_request
    def first():
        print("我是第一次")
     
    @app.route("/")
    def index():
        print("我是响应函数")
        return "ok"
     
    if __name__ == '__main__':
     
        app.run()
    

    响应函数的执行顺序:

    响应函数之前执行的顺序

    响应函数之后执行的顺序

    after_request必须接收一个参数,参数为response对象,而且必须返回。

    总结(执行顺序按下面的编号)

    1 before_first_request 当项目启动后,接收到的第一个请求,就会执行before_first_request装饰的函数,执行顺序也是谁先注册就谁先执行
     
    2 before_request 请求没有经过响应函数的时候,会执行before_request装饰的函数,谁先注册谁先执行。只要有一个函数有返回值,后面的所有before_request都不会执行,且响应函数也不会执行。其有没有返回值都不会影响after_request的执行
     
    3 after_request是再before_request与响应函数执行后执行。他必须接收响应参数,并且要把响应返回。执行顺序是谁先注册后执行。
    

    请求扩展之错误处理

    • teardown_request用来捕获错误,无论有没有出现错误都会执行,如果没有错误接收的错误就是none,如果有错误就会接收到错误。但是它不能处理错误。
    • errorhandler(错误状态码),针对不同的状态码,执行不同函数,没有错误就不会执行,如果有错误就会处理错误。
    from  flask import Flask,request,render_template
     
    app  = Flask(__name__)
     
    @app.teardown_request
    def tear(e):
         print(e)
         print("我是teardown_request")
     
     
    @app.errorhandler(500)
    def error_500(e):
        print(e)
        return "我程序崩了,你下次来把"
     
    @app.errorhandler(404)
    def error_404(e):
        print(e)
        return render_template("404.html")
     
     
    @app.route("/")
    def index():
     
        print("我是响应函数")
        return render_template("index.html")
     
     
    if __name__ == '__main__':
     
        app.run()
    

    总结:

    1 teardown_request,一旦遇到错误就会执行,并且把错误传递给teardown_request装饰的函数, 没有错误也会执行,但是是错误为None,他并不能处理错误,只能记录
    2 errorhandle 可以捕获错误,并且对错误做出响应,返回给用户,如果你要用errorhandler你必须指定他捕获哪种类型的错误,就必须传错误码,然后就返回值,返回给用户
    

    请求扩展之标签与过滤器

    from  flask import Flask,request,render_template
     
    app  = Flask(__name__)
     
     
    #相当于django中的标签。
    @app.template_global()
    def get_sb(a1,a2):
        return a1 + a2
     
    #再html中的用法{{get_sb(1,2)}}
     
    #django中的过滤器,以一个参数是你要过滤的那个值
    @app.template_filter()
    def get_something(a1,a2,a3,a4):
        return a1+a2+a3+a4
     
    #再html中{{1|4,2,3}}
     
     
    @app.route("/")
    def index():
     
        print("我是响应函数")
        return render_template("index.html")
     
     
    if __name__ == '__main__':
     
        app.run()
    
  • 相关阅读:
    Web开发利器Webstorm导入多个文件夹或者项目
    js react 全选和反选
    nginx的配置文件 【nginx.conf】
    nginx 服务器重启命令,关闭
    Nginx反向代理新篇-使用location对多个URL做反向代理
    Windows下Nginx的安装与配置
    es6 递归 tree
    自定义table样式
    数据库(7)
    数据库(6)
  • 原文地址:https://www.cnblogs.com/cnhyk/p/12758354.html
Copyright © 2011-2022 走看看