python

超轻量级php框架startmvc

Flask框架重定向,错误显示,Responses响应及Sessions会话操作示例

更新时间:2020-07-20 15:30:01 作者:startmvc
本文实例讲述了Flask框架重定向,错误显示,Responses响应及Sessions会话操作。分享给大家供大家

本文实例讲述了Flask框架重定向,错误显示,Responses响应及Sessions会话操作。分享给大家供大家参考,具体如下:

重定向和错误显示

将用户重定向到另一个端点,使用redirect(), 要提前中止错误请求,请使用abort()函数


from flask import abort, redirect, url_for
@app.route('/')
def index():
 return redirect(url_for('login'))
@app.route('/login')
def login():
 abort(401)
 this_is_never_executed()

默认情况下,会为每个错误代码显示黑白错误页面,如果要自定义错误页面,请使用errorhandler() 装饰器.

Responses

  1. 如果返回了正确类型的响应对象,则直接从视图返回。
  2. 如果是字符串,则使用该数据和默认参数创建响应对象。
  3. 如果返回元组,则元组中的项可以提供额外信息。这样的元组必须是这样的形式,或者至少有一个项必须在元组中。该值将覆盖状态代码,可以是其他标头值的列表或字典。(response, status, headers)或者是(response, headers)

如果要在视图中获取生成的响应对象,可以使用make_response() 函数

假设你有如下视图:


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

使用make_response()包含返回表达式,获取响应对象并修改它,然后返回它


@app.errorhandler(404)
def not_found(error):
 resp = make_response(render_template('error.html'), 404)
 resp.headers['X-Something'] = 'A value'
 return resp

Sessions会话追踪

session在cookie的基础上实现的,并以加密方式对cookie进行签名

要使用sessions,必须要设置私钥,以下是简单示例:


from flask import Flask, session, redirect, url_for, escape, request
app = Flask(__name__)
# Set the secret key to some random bytes. Keep this really secret!
app.secret_key = b'_5#y2L"F4Q8z\n\xec]/'
@app.route('/')
def index():
 if 'username' in session:
 return 'Logged in as %s' % escape(session['username'])
 return 'You are not logged in'
@app.route('/login', methods=['GET', 'POST'])
def login():
 if request.method == 'POST':
 session['username'] = request.form['username']
 return redirect(url_for('index'))
 return '''
 <form method="post">
 <p><input type=text name=username>
 <p><input type=submit value=Login>
 </form>
 '''
@app.route('/logout')
def logout():
 # remove the username from the session if it's there
 session.pop('username', None)
 return redirect(url_for('index'))

希望本文所述对大家基于flask框架的Python程序设计有所帮助。

Flask 重定向 错误 Responses响应 Sessions会话