Flask中请求钩子和上下文以及异常处理 学习

系列文章目录



一、请求钩子学习

介绍:

1.为了让每个视图函数避免编写重复功能的代码,Flask提供了通用设施的功能,即请求钩子。
2.请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子:

请求钩子是通过装饰器的形式实现,Flask支持如下四种请求钩子:

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

2.before_request
- 在每次请求前执行
- 如果在某修饰的函数中返回了一个响应,视图函数将不再被调用

3.after_request
- 如果没有抛出错误,在每次请求后执行
- 接受一个参数:视图函数作出的响应
- 在此函数中可以对响应值在返回之前做最后一步修改处理
- 需要将参数中的响应在此参数中进行返回

4.teardown_request:
- 在每次请求后执行
- 接受一个参数:错误信息,如果有相关错误抛出

代码示例:

from flask import *

app=Flask(__name__)

# 在第一次请求之前调用,可以在此方法内部做一些初始化操作
@app.before_first_request
def before_first_requests():
    print('服务器第一次接受请求的时候执行')

# 在每一次请求之前调用,这时候已经有请求了,可能在这个方法里面做请求的校验
# 如果请求的校验不成功,可以直接在此方法中进行响应,直接return之后那么就不会执行视图函数
@app.before_request
def before_request():
    print('每次视图函数执行之前执行')
    #如果有return,后面的视图函数就不执行了
    #return "提前结束“
    # if 请求不符合条件:
    # return "laowang"

# 在执行完视图函数之后会调用,并且会把视图函数所生成的响应传入,可以在此方法中对响应做最后一步统一的处理
@app.after_request
def after_request(resp):
    print('每次视图函数执行之后执行')
    return resp

# 每一次请求之后都会调用,会接受一个参数,参数是服务器出现的错误信息
@app.teardown_request
def teardown_request(resp):
    print('请求结束时执行!')

@app.route('/test1')
def test1():
    return "请求开始"

@app.route('/test2')
def test2():
    return "请求钩子结束"


if __name__ == '__main__':
    app.run()



'''contex_processor: 当项目中的所有模板都需要一个参数的时候,可以在context_processor钩子函数定义,并且自动传给所有模板,该函数一定要返回字典 '''

第一次执行:
在这里插入图片描述

第二次执行
在这里插入图片描述

1、通过对比可以发现第二次执行时,@app.before_first_request 装饰器并没有执行,因为在第一次调用时,就已经把准备工作做好。
2、它的工作如
在请求开始时,建立数据库连接;
在请求开始时,根据需求进行权限校验;

二、上下文

介绍

上下文:即语境,语意,在程序中可以理解为在代码执行到某一时刻时,根据之前代码所做的操作以及下文即将要
执行的逻辑,可以决定在当前时刻下可以使用到的变量,或者可以完成的事情。
Flask中有两种上下文,请求上下文和应用上下文
Flask中上下文对象:相当于一个容器,保存了 Flask 程序运行过程中的一些信息。

1.请求上下文

  • 思考:在视图函数中,如何取到当前请求的相关数据?
    比如:请求地址,请求方式,cookie等等
    在 flask 中,可以直接在视图函数中使用 request 这个对象进行获取相关数据,而 request 就是请求上下文的对
    象,保存了当前本次请求的相关数据,请求上下文对象有:request、session
  • request
    封装了HTTP请求的内容,针对的是http请求。举例:user = request.args.get(‘user’),获取的是get请
    求的参数。
  • session
    用来记录请求会话中的信息,针对的是用户信息。举例:session[‘name’] = user.id,可以记录用户信息。
    还可以通过session.get('name’获取用户信息。

2.应用上下文

它的字面意思是 应用上下文,但它不是一直存在的,它只是request context 中的一个对 app 的代理(人),所谓
local proxy。它的作用主要是帮助 request 获取当前的应用,它是伴 request 而生,随 request 而灭的。
应用上下文对象有:current_app,g
current_app
应用程序上下文,用于存储应用程序中的变量,可以通过current_app.name打印当前app的名称,也可以在
current_app中存储一些变量,例如:
应用的启动脚本是哪个文件,启动时指定了哪些参数
加载了哪些配置文件,导入了哪些配置
连了哪个数据库
有哪些public的工具类、常量
应用跑再哪个机器上,IP多少,内存多大

注意:
current_app 就是当前运行的flask app,在代码不方便直接操作flask的app对象时,可以操作current_app就等 价于操作flask app对象

代码示例

from flask import Flask, current_app
app= Flask(__name__)
# 以ywx客户端对象为例
# 用字符串表示创建的ywx客户端
# 为了方便在各个视图中使用,将创建的ywx客户端对象保存到flask app中,
# 后续可以在视图中使用current_app.ywx获取
app.ywx = 'hello flask'

@app.route('/test')
def test():
	return current_app.ywx
if __name__ == '__main__':
    app.run()

客户端请求界面:

在这里插入图片描述

3.G对象

  • g 作为 flask 程序全局的一个临时变量,充当中间媒介的作用,我们可以通过它在一次请求调用的多个函数间传递一些数据。
  • 每次请求都会重设这个变量。

g对象可以结合前面学的蓝图来使用(感兴趣的可以去看前面章节flask 蓝图学习)

  1. 在蓝图包中创建一个新的蓝图:

在这里插入图片描述

  1. 在创建定义 g变量py文件。

在这里插入图片描述
3. 在整个项目里面建一个调用g变量的py文件
在这里插入图片描述
4. 在应用程序中调用g变量

在这里插入图片描述
5. 在服务器端可以访问得到
在这里插入图片描述

  1. 在浏览器端界面

在这里插入图片描述

三、异常处理

一、HTTP 异常主动抛出

  • abort 方法
    抛出一个给定状态代码的 HTTPException 或者 指定响应,例如想要用一个 页面未找到异常来终止请
    求,你可以调用 abort(404)。
  • 参数:
    code – HTTP的错误状态

abort(404)
abort(500)

抛出状态码的话,只能抛出 HTTP 协议的错误状态码

二、捕获错误

  • errorhandler 装饰器
    注册一个错误处理程序,当程序抛出指定错误状态码的时候,就会调用该装饰器所装饰的方法
  • 参数:
    code_or_exception – HTTP的错误状态码或指定异

1.可以在templates下新建html报错文件,通过errorhandler 装饰器 当报指定的错误时,可以通过render_template函数。
2.将其报错信息跳转到客户端(浏览器)显示

from flask import *

app=Flask(__name__)

@app.route('/')
def hello_world():
    1/0
    #接受一个请求参数
    name=request.args.get('name')
    if name:
        print(name)
    else:
        abort(500)
        print('后面代码不执行')
        return 'hello world!'

@app.errorhandler(404)
def error_ym(error):
    print(error)
    return render_template('404.html'),404

@app.errorhandler(500)
def error_sr(error):
    print(error)
    return render_template('500.html'),500
if __name__ == '__main__':
    app.run()

请求出错时显示自定义的报错信息!
在这里插入图片描述

自定义的html报错文件
在这里插入图片描述

总结

以上是对本章的学习笔记,有不足或不对的地方望指证!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值