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
- 如果返回了正确类型的响应对象,则直接从视图返回。
- 如果是字符串,则使用该数据和默认参数创建响应对象。
- 如果返回元组,则元组中的项可以提供额外信息。这样的元组必须是这样的形式,或者至少有一个项必须在元组中。该值将覆盖状态代码,可以是其他标头值的列表或字典。(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程序设计有所帮助。