除请求对象之外,还有一个session对象。它允许你在不同请求储存特定用户的信息。它是在Cookies的基础上实现的,并且对,Cookies进行密钥签名要使用会话,你需要设置一个密钥。
(app.session_interface对象)
使用必须先设置一下密钥:app.secret_key = 'xxxx'
session['name'] = 'xxx' #放值
session['name'] # 取值
源码执行流程
1.save_session -- 响应的时候,把session中的值加密序列化到cookie中,返回到浏览器中
2.open_session -- 请求来了,从cookie中取值,反解生成session对象,以后再视图函数中直接用session就可以了
#设置值
flash('我错了')
flash('超时错误',category='x1')
#取值:一旦取过一次,在另一个函数中再取就没了
get_flashed_messages()
get_flashed_messages(category_filter=['x1','x2'])
#使用场景:在某个位置放一个值,过来去取出来
from flask import Flask, get_flashed_messages, flash, url_for
app = Flask(__name__)
app.secret_key = 'xxxxadadad'
@app.route('/', methods=['GET', 'POST'])
def index():
# error='我出错了'
# url=url_for('test')
# url=url+'?error=%s'%error
# 使用flash实现,相当于在某个位置放了值
flash('我出错了', category='xxx')
url = url_for('test')
# return redirect(url)
return 'ok'
@app.route('/test/', methods=['GET', 'POST'])
def test():
# error=request.args.get('error')
# print(error)
# 使用闪现
# 从某个位置取出来值
error = get_flashed_messages(category_filter=['xxx'])
print(error)
return 'ok'
@app.route('/test2/', methods=['GET', 'POST'])
def test2():
# error=get_flashed_messages()
# print(error)
flash('我出错了')
return 'test2'
if __name__ == '__main__':
app.run()
类比Django中间件中的process_request,在请求收到之前绑定一个函数做一些事情
@app.before_request
def before_request():
print('来了')
类比Django中间件中的process_response,每一个请求之后绑定一个函数,如果请求没有异常
@app.after_request
def after_request(response):
print(type(response))
print('走了了')
return response
@app.before_first_request
def first():
print('我的第一次')
无论如何都会走,即便出了异常
@app.teardown_request
def ter(e):
print(e)
print('无论如何都会走,即便出了异常')
路径存在时404,服务器内部错误500
@app.errorhandler(404)
def error_404(arg):
# return render_template('')
return '你迷路了'
标签
@app.template_global()
def sb(a1, a2):
return a1 + a2
#{{sb(1,2)}}
过滤器
@app.template_filter()
def db(a1, a2, a3):
return a1 + a2 + a3
#{{ 1|db(2,3)}}
总结:
注意有多个的情况,执行顺序(before_request按照顺序往下依次执行,after_request最后一个开始依次往上)。before_request请求拦截后(也就是有return值),response所有都执行。
原文:https://www.cnblogs.com/ShenJunHui6/p/11219490.html