您好,登录后才能下订单哦!
小编给大家分享一下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框架重定向,错误显示,Responses响应及Sessions会话操作的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。