今日内容概要

  • 请求扩展
  • 蓝图
  • g对象

内容详细

1、请求扩展

# 在请求来了,请求走了,可以做一些校验和拦截,通过装饰器来实现 7 个

# 1 before_request
类比django中间件中的process_request,在请求收到之前绑定一个函数做一些事情 # 2 after_request # 3 before_first_request # 4 teardown_request # 5 errorhandler # 6 template_global # 7 template_filter
from flask import Flask, request, render_template

app = Flask(__name__)

# app.debug = True

# 1. 请求扩展之before_request,在进入视图函数之前执行,如果有多个,是从上往下执行
@app.before_request
def before():
# 判断是否登录,如果登录了继续往下走,如果没登陆
# request.xxx='lqz' 可以往请求中放值,后续可以取出来,只针对于当次请求有效
print("我执行了1111") # @app.before_request # 多个before_request 从上往下 只执行一次
# def before1():
# # 判断是否登录,如果登录了继续往下走,如果没登陆
# print("我执行了2222") # 2. 请求走了,会执行它,注册多个,按照从下往上的顺序执行
@app.after_request
def after(response):
# 写入cookie,写入响应头。。。处理跨域
print(response)
print("请求走了1111")
return response # @app.after_request
# def after2(response):
# print(response)
# print("请求走了2222")
# return response # 3. before_first_request 只会执行一次,以后就不执行了,跟用户无关,做一些初始化的工作
@app.before_first_request
def first():
print("我的第一次") # 4. teardown_request 每一个请求之后绑定一个函数,即使遇到了异常,debug为false的情况下
@app.teardown_request
def teardown(e):
print(e) # 记录日志,错误日志request.method
print("我是teardown") # 5. errorhandler 绑定响应状态码,当状态码一致,就会执行它
@app.errorhandler(404)
def err_404(arg):
print(arg)
return render_template('404.html') @app.errorhandler(500) # 500错误的返回
def err_500(arg):
print(arg)
return render_template('500.html') # 6. 标签template_global
@app.template_global()
def add(a1, a2):
return a1 + a2 # 7. 过滤器template_filter
@app.template_filter()
def add2(a1, a2, a3):
return a1 + a2 + a3 @app.route('/')
def index():
# raise Exception("错误") l = [1, 2, 4]
print(l[9])
print("我是视图函数")
return "hello web" @app.route("/home")
def home():
return render_template('home.html') if __name__ == '__main__':
app.run()

2、蓝图

# blueprint
现在项目都是单个py文件--》想划分目录--》自己定制目录结构--》app经常用---》各个文件中导来导去---》出现循环引入问题 # 一个项目有多个app,每个app有自己一套路由,使用蓝图来管理 # 第一步:定义蓝图对象
user = Blueprint('user', __name__) # 第二步:使用蓝图写路径,写请求扩展(只针对于当前蓝图生效)
@user.route('/index') # 第三步:把蓝图注册进app中
app.register_blueprint(user) # 小型项目目录划分
pro_flask
-pro_flask
-__init__.py
-statics
-templates
-views
account.py
user.py
blog.py
-run.py # 大型项目 --》有多个app
pro_flask
-pro_flask # 包
__init__.py # 包的init
admin # 包
__init__.py # 包的init
static # 自己的静态文件
templates # 自己的模板文件
models.py
views.py # 自己的视图函数
web # 包
__init__.py
static
templates
views.py run.py # 启动文件 # 以后如何划分,千奇百怪,但是都使用蓝图来做,蓝图管理自己的路由和请求扩展

3、g对象

# global的缩写,为了实现在同一个请求中,传递数据,上下文传递,赋值取值只针对于当次请求生效

# 类比 django 中的 request对象,内有context 属性
django中间件中,假设想放到request中一个数据
request.name="lqz"
rerquest.context['name']='lqz'
rerquest.context['method']='nb'
到视图函数中,就可以取出来 # g和session有什么区别?
g只针对于当次请求
session针对于多次请求
from flask import Flask, request, g

app = Flask(__name__)

@app.route('/')
def index():
print("我是视图函数")
# request.a=1
# request.b=2
# 当次请求中的上下文
g.a = 1
g.b = 3
print(add())
return "hello web" @app.route('/home')
def home():
g.a = 3
g.b = 5
print(add())
return "hello home" def add():
return g.a + g.b
# return request.a+request.b if __name__ == '__main__':
app.run()

请求扩展、蓝图、g对象的更多相关文章

  1. flask框架(七)——蓝图、请求上下文、g对象、信号、flask_session

    蓝图 作用:对程序进行目录结构划分 不使用蓝图情况下,自己分文件 目录结构: -templates -views -__init__.py -user.py -order.py -app.py app ...

  2. flask系列八之请求方法、g对象和钩子函数

    一.get方法 ,post方法 post请求在模板中要注意几点: (1)input标签中,要写name来标识这个value的key,方便后台获取. (2)在写form表单的时候,要指定method=' ...

  3. 中间件、蓝图、g对象

    中间件 ''' flask中一旦请求到来,要执行app()--->>>执行的是app.__call__,整个flask的入口 ''' from flask import Flask ...

  4. Flask中current_app和g对象

      Flask零基础到项目实战(七)请求方法.g对象和钩子函数 一.get方法 二.post方法 post请求在模板中要注意几点: input标签中,要写name来标识这个value的key,方便后台 ...

  5. Flask的闪现(message) 请求扩展 中间件 蓝图

    补充:一个编程思路 需求:做一些邮件短信微信的消息通知,比如账单告警之类的:比如数据库操作,数据库种类繁多:缓存的选择比如redis/memcache,诸如此类需要进行选择配置,如果我们单纯的用函数去 ...

  6. Flask框架(三)—— 请求扩展、中间件、蓝图、session源码分析

    Flask框架(三)—— 请求扩展.中间件.蓝图.session源码分析 目录 请求扩展.中间件.蓝图.session源码分析 一.请求扩展 1.before_request 2.after_requ ...

  7. Flask框架 (四)—— 请求上下文源码分析、g对象、第三方插件(flask_session、flask_script、wtforms)、信号

    Flask框架 (四)—— 请求上下文源码分析.g对象.第三方插件(flask_session.flask_script.wtforms).信号 目录 请求上下文源码分析.g对象.第三方插件(flas ...

  8. 第二篇 Flask基础篇之(闪现,蓝图,请求扩展,中间件)

    本篇主要内容: 闪现 请求扩展 中间件 蓝图 写装饰器,常用 functools模块,帮助设置函数的元信息 import functools def wrapper(func): @functools ...

  9. Flask10 登录模块、表单框架、表单渲染、表单验证、bookie、请求之前钩子、g对象、编写装饰器

    from flask import Flask from flask import request from flask import render_template from flask_wtf i ...

随机推荐

  1. 修改openstack Centos镜像的默认用户的密码

    Ubuntu官方提供的OpenStack镜像是用Key来登录的,太麻烦,可以改成用密码来登录. 修改image的工具叫:guestfish. yum install libguestfs-tools ...

  2. Python中查看变量的类型,内存地址,所占字节的大小

    查看变量的类型 #利用内置type()函数 >>> nfc=["Packers","49"] >>> afc=[" ...

  3. 单页应用SPA开发最佳实践

    最近用vue+vue-router做了个单页应用的项目,页面大概有15个左右.积累了一些开发经验在此做一些记录.本文主要从可维护性方面来考虑SPA的开发实践 全站的颜色定义放在一个less或者scss ...

  4. 每日所学之自学习大数据的Linux环境配置2

    今天设置网络 出现报错 明天找时间解决 不用解决了 刚才试了以下 又能下载了 描述一下问题: cannot find a valid baseurl for repo:base/7/x86_64 如果 ...

  5. Visual Studio 2022 git error Unable to negotiate with xx.xxx.xxxx port 22: no matching host key type found. Their offer: ssh-rsa

    前言 前两天因为升级了Git导致git提交拉取的时候都提示下面这个异常,然后经过一番折腾以后终于把这个问题解决了.但是今天我升级了下Visual Studio 2022将其升级到了17.1.3版本然后 ...

  6. CTF大赛模拟-CFS三层内网漫游

    CTF大赛模拟-CFS三层内网漫游 环境: 三台虚拟机,三个网络. target 1:192.168.161.178 ,192.168.52.132 (linux) target 2:192.168. ...

  7. Python入门-面向对象三大特性-封装

    一.封装 封装,顾名思义就是将内容封装到某个地方,以后再去调用被封装在某处的内容. 所以,在使用面向对象的封装特性时,需要: 将内容封装到某处 从某处调用被封装的内容 第一步:将内容封装到某处 sel ...

  8. 【面试普通人VS高手系列】谈谈你对Seata的理解

    很多面试官都喜欢问一些"谈谈你对xxx技术的理解". 大家遇到这种问题时,是不是完全不知道从何说起. 那么我们来看一下,普通人和高手是如何回答这个问题的? 普通人: Seata是用 ...

  9. java_类的访问控制符

    1.分类: public protected default private是java中的访问控制修饰符. public String name; protected String name; Str ...

  10. docker容器编排原来这么丝滑~

    前言: 请各大网友尊重本人原创知识分享,谨记本人博客:南国以南i 概念介绍: Docker Docker 这个东西所扮演的角色,容易理解,它是一个容器引擎,也就是说实际上我们的容器最终是由Docker ...