Flask学习之请求钩子、状态保持、上下文、flash消息闪现、重定向

本文详细介绍了Flask框架中的请求钩子,包括before_first_request、before_request、after_request和teardown_request的用法。接着讲解了状态保持,涉及cookie和session的设置、获取及删除。特别强调了Flask中session的特性和过期时间配置。此外,还讨论了上下文的概念,包括请求上下文和应用上下文的作用。最后,介绍了如何实现flash消息闪现以及重定向和URL反向解析的使用方法。
摘要由CSDN通过智能技术生成

请求钩子(类似于django的中间件)

  • before_first_request:在第一次请求之前运行,只需执行一次,适合:初始化操作,比如数据库连接操作
  • before_request:在每一次请求都会执行,可以在这里做权限校验操作,比如说某用户是黑名单用户,黑名单用户登录系统将遭到拒绝访问,可以使用before_request进行权限校验。
  • after_request:在请求之后运行,会接收一个参数,这个参数就是前面的请求处理完毕之后返回的响应数据,可以对响应做最后一步统一的处理
  • teardown_request:每一次请求之后都会调用,会接受一个参数,参数是服务器出现的错误信息,适合:用来记录服务器内部异常,服务器日志记录使用
@app.before_first_request
def before_first_request():
    # 没有返回值
    print('first')

@app.before_request
def before_request():
    print('before request')
    # 如果请求的校验不成功,可以直接在此方法中进行响应,直接return之后那么就不会执行视图函数
    # if 请求不符合要求:
    # return 'woshishui'

@app.after_request
def after_request(response):
    print('after_request')
    # 可以修改返回的响应,也可以不修改
    response.headers['Content-Type'] = "application/json"
    return response

@app.teardown_request
def teardown_request(e):
    print('teardown_request')
    print(e)

状态保持

flask和之前用过的其他框架有一点不同的是,它的session默认是完全保留在客户端浏览器中的,也就是说往flask的session中写入数据,最终这些数据将会以json字符串的形式,经过base64编码写入到用户浏览器的cookie里,也就是说无须依赖第三方数据库保存session数据,也无需依赖文件来保存。
在这里插入图片描述

cookie设置和获取

当浏览器访问服务器的时候,由服务器设置一些状态信息到浏览器中,存储在客户端(浏览器)

设置cookie

from flask import Flask, make_response, request
@app.route('/cookie')
def set_cookie(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值