Frasco - redirecionamento e erros
A classe Flask tem um redirect()função. Quando chamado, ele retorna um objeto de resposta e redireciona o usuário para outro local de destino com o código de status especificado.
Protótipo de redirect() a função é como abaixo -
Flask.redirect(location, statuscode, response)
Na função acima -
location parâmetro é o URL para onde a resposta deve ser redirecionada.
statuscode enviado para o cabeçalho do navegador, o padrão é 302.
response parâmetro é usado para instanciar a resposta.
Os seguintes códigos de status são padronizados -
- HTTP_300_MULTIPLE_CHOICES
- HTTP_301_MOVED_PERMANENTLY
- HTTP_302_FOUND
- HTTP_303_SEE_OTHER
- HTTP_304_NOT_MODIFIED
- HTTP_305_USE_PROXY
- HTTP_306_RESERVED
- HTTP_307_TEMPORARY_REDIRECT
o default status código é 302, que é para ‘found’.
No exemplo a seguir, o redirect() A função é usada para exibir a página de login novamente quando uma tentativa de login falha.
from flask import Flask, redirect, url_for, render_template, request
# Initialize the Flask application
app = Flask(__name__)
@app.route('/')
def index():
return render_template('log_in.html')
@app.route('/login',methods = ['POST', 'GET'])
def login():
if request.method == 'POST' and request.form['username'] == 'admin' :
return redirect(url_for('success'))
else:
return redirect(url_for('index'))
@app.route('/success')
def success():
return 'logged in successfully'
if __name__ == '__main__':
app.run(debug = True)
Classe Flask tem abort() função com um código de erro.
Flask.abort(code)
o Code parâmetro assume um dos seguintes valores -
400 - para solicitação incorreta
401 - para não autenticado
403 - para proibido
404 - para não encontrado
406 - para não aceitável
415 - para tipo de mídia não suportado
429 - Muitos pedidos
Vamos fazer uma pequena mudança no login()função no código acima. Em vez de exibir novamente a página de login, se‘Unauthourized’ página deve ser exibida, substitua-a por uma chamada para abort(401).
from flask import Flask, redirect, url_for, render_template, request, abort
app = Flask(__name__)
@app.route('/')
def index():
return render_template('log_in.html')
@app.route('/login',methods = ['POST', 'GET'])
def login():
if request.method == 'POST':
if request.form['username'] == 'admin' :
return redirect(url_for('success'))
else:
abort(401)
else:
return redirect(url_for('index'))
@app.route('/success')
def success():
return 'logged in successfully'
if __name__ == '__main__':
app.run(debug = True)