首页 > 其他分享 >flask闪现,请求扩展,g对象

flask闪现,请求扩展,g对象

时间:2023-08-03 18:01:05浏览次数:35  
标签:return 请求 flask 闪现 app request print def

1 闪现

# 一个请求---》假设出错了---》重定向到另一个地址---》把错误信息在另一个返回中看到
错误信息放个位置----》另一个请求过来,去那个位置拿
# 把一些数据,放在某个位置---》后期可以去取出来----》取完不用删除,就没了
def index():
    s='xx错位了'
    return redirect('/errors')

def errors():
    return index.html



# 如何设置
flash('aaa')
# 如何取
get_flashed_message()

# 分类放
flash('超时错误', category="x1")
# 分类取
data = get_flashed_messages(category_filter=['x1'])
from flask import Flask,flash,get_flashed_messages

app=Flask(__name__)
app.debug=True
app.secret_key='asdfasdfasdfa'
# 只要用闪现---》就要设置secret_key----》放到session中了

@app.route('/')
def index():
    # 放入我的名字
    # flash('lqz')  # 放哪了?

    # 分类放
    flash('超时错误', category="x1")
    return 'xxx'
@app.route('/home')
def home():
    # 取出我的名字
    name=get_flashed_messages(category_filter=['x2'])
    print(name)
    return 'home'

@app.route('/order')
def order():
    # 取出我的名字
    # name=get_flashed_messages()
    # print(name)
    data = get_flashed_messages(category_filter=['x1'])
    print(data)
    # 按分类取
    return 'home'
if __name__ == '__main__':
    app.run(port=8080)
# 1 django 的message就是做这个事的
# 2 闪现有什么用?
	-暂时存数据
    -当次请求出错了,下次请求要显示这个错误

2 请求扩展

# 类似于django中的中间件
	-请求来了,请求走了,做一些拦截
        1 before_request
        2 after_request
        3 before_first_request
        4 teardown_request#日志
        5 errorhandler#异常
        6 template_global
        7 template_filter
        
        
# before_request 每个请求来了,都会走

before_request

# 请求来了执行---》process_request--->可以下多个,从上往下依次执行
@app.before_request
def before():
    # 当次请求的对象就是request
    # 1  判断访问的不同路径
    # if request.path=='/':
    #     print('我来了')
    # else:
    #     print('访问其他路径')
    # 2 判断如果是跟路径,向request对象中放个name,其他不放
    # if request.path == '/':
    #     request.name = 'lqz'
    # else:
    #     print('访问其他路径')

    # 3 返回None,会执行下一个请求扩展,如果返回4件套,直接就返回了,不再往下执行了
    # if request.path=='/':
    #     return '不让你访问'
    # else:
    #     print('访问其他路径')
    # 4 多个before_request,从上往下执行
    print('1111')


@app.before_request
def before2():
    print('2222')

after_request

@app.after_request
def after2(response):
    print('走了走了222')
    return response


@app.route('/')
def index():
    # print(request.name)
    return 'xxx'

before_first_request

# 项目运行起来的第一次会执行,以后再也不执行了
# 1.x可以,2.x弃用了

teardown_request

# teardown_request 每一个请求之后绑定一个函数,即使遇到了异常---》一般用来记录日志--->不能做统一异常处理
@app.teardown_request
def ttt(e):
    # 通过判断e是否为空,记录日志
    print(e)  # 出了异常,e就是异常对象,如果没有异常,e就是None
    print('来了老弟')
    if e:
        return '出异常了'

errorhandler

## errorhandler
@app.errorhandler(404)
def error(e):
    print(e)
    print('xxx')
    return render_template('error.html')


@app.errorhandler(500)
def error1(e):
    print(e)
    print('500')
    return jsonify({'code': 999, 'msg': '服务器内部错误,请联系系统管理员'})

template_global全局标签

# template_global 全局标签,所有页面都可以用
@app.template_global()
def add(a1, a2):
    return a1 + a2

template_filter全局过滤器

# template_filter 全局过滤器
@app.template_filter()
def db(a1, a2, a3):
    print(a1)
    return a1 + a2 + a3
<h2>使用全局标签</h2>
{{add(4,5)}}

<h2>使用全局过滤器</h2>

{{4|db(5,6)}}

4 g对象

# 请求来了,在request中放个path,后续的视图函数中都能拿到
# flask不建议向request对象中放变量,建议使用g对象

# g对象,当次请求中放入的变量,在当次请求中一直存在

# global的缩写,global


# g和session的区别
	-g只针对于当次请求
    -session可以跨请求
    g.name = 'tom'
    print(g.name)

标签:return,请求,flask,闪现,app,request,print,def
From: https://www.cnblogs.com/liyuanxiangls/p/17604063.html

相关文章

  • jQuery--ajax请求
    jquery简化了ajax请求的步骤,使用三个函数就可以实现ajax请求的处理一、函数(1)实现ajax的核心函数$.ajax()(2)post方式发送ajax请求$.post()(3)get方式发送ajax请求$.get()$.post和$.get是在内部调用$.ajax() 二、使用$.ajax函数//$.ajax()的参数是一个json的结构$.ajax({......
  • (一)flask学习笔记
    1、flask路由(用了装饰器)@app.route('/login',methods=["GET","POST"])deflogin():pass2、路由参数@app.route('/login',methods=["GET","POST"],endpoint='login')deflogin():pass  ......
  • 【HMS Core】位置服务逆地理编码请求错误问题
    【关键字】HMS、位置服务、逆地理编码【问题描述】有开发者反馈在集成位置服务-逆地理编码时,出现了请求报错的问题。后端请求逆地理编码错误{   "returnCode":"010010",   "returnDesc":"INVALID_REQUEST"}【问题分析】1、一开始认为是cp的请求参数有误,缺少了必选的参数。......
  • flask初体验和fastapi初体验
    0.flask的介绍#python界的web框架 -Django:大而全,快速开发,公司内部项目-Flask:小而精,不具备web开发好多功能,丰富的第三方插件-FastApi:异步框架,主要为了做前后端分离接口-Sanic:异步框架,只支持python3.6及以上,性能比较高-Tornado:公司用的比较少。。。1.fl......
  • 跨域请求是什么
    跨域请求(Cross-OriginRequest),简称CORS,是指在Web开发中,当一个Web页面向不同源(域名、协议或端口)的服务器发起请求时,浏览器会遵循同源策略(Same-OriginPolicy)的限制,对这些跨源请求进行限制。同源策略是一种安全策略,它限制了来自不同源的脚本在浏览器中运行。一个源指的是由协议、主......
  • 封装的axios请求
    axios实例常用配置letrequest=axios.create({baseURL:'http://localhost:8080',//请求的域名,基本地址timeout:5000,//请求的超时时长,单位毫秒url:'/data.json',//请求的路径method:'get,post,put,patch,delete',//请求方法headers:{token:''//比如to......
  • 请求头详解——Headers
    请求头定义:客户端,即浏览器通过输入url后确定等于做了一次向服务器的请求动作,在这个请求里面带有请求参数,请求参数的集合即为请求头。请求头的参数(常用的):Accept:浏览器可接收的文件类型Accept-Charset:浏览器可以接收的编码类型Accept-Encoding:浏览器可以接收的压缩编码类型Ac......
  • js 发起get请求
      leta=document.createElement('img');a.src='/_xxxxxx=1&e=0.5609369440726193'在浏览器中,当创建一个图片元素并设置src属性时,浏览器会根据该路径发送一个HTTP请求,请求该路径对应的资源文件。这个资源文件可以是一张图片、一个音频文件、一个视频文件或者其他可以......
  • vue中使用axios发送请求时在header中设置请求头发现请求发送两次
    问题:vueaxios跨域请求,在RequestHeaders加Authorization传递Token时,发现统一请求触发了两次,第一次是RequestMethod:OPTIONS请求。原因:跨域请求时,浏览器会首先使用OPTIONS方法发起一个预请求,判断接口是否能够正常通讯。如果通讯异常,则不会发送真正的请求,如果测试通讯正常,则开......
  • antd upload vue3 取消请求,取消进行中的接口请求
    在使用antdupload组件时,大文件上传等待时长太久,在上传过程中想取消上传,即取消进行中的接口请求。不解释,上代码:importaxiosfrom'axios';<a-uploadv-model:file-list="fileList"name="file":multiple="true":action=......