Flask - przekierowanie i błędy
Klasa kolby ma redirect()funkcjonować. Po wywołaniu zwraca obiekt odpowiedzi i przekierowuje użytkownika do innej lokalizacji docelowej z określonym kodem stanu.
Prototyp redirect() funkcja jest jak poniżej -
Flask.redirect(location, statuscode, response)
W powyższej funkcji -
location parametr to adres URL, na który należy przekierować odpowiedź.
statuscode wysyłane do nagłówka przeglądarki, domyślnie 302.
response parametr służy do tworzenia wystąpienia odpowiedzi.
Następujące kody stanu są znormalizowane -
- 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
Plik default status kod jest 302, który jest przeznaczony dla ‘found’.
W poniższym przykładzie redirect() Funkcja służy do ponownego wyświetlenia strony logowania, gdy próba logowania się nie powiedzie.
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)
Klasa kolby ma abort() funkcja z kodem błędu.
Flask.abort(code)
Plik Code parametr przyjmuje jedną z następujących wartości -
400 - dla złego żądania
401 - w przypadku nieuwierzytelnionych
403 - za zabronione
404 - dla Nie znaleziono
406 - niedopuszczalne
415 - dla nieobsługiwanego typu nośnika
429 - Za dużo żądań
Zróbmy niewielką zmianę w login()funkcja w powyższym kodzie. Zamiast ponownie wyświetlać stronę logowania, jeśli‘Unauthourized’ ma zostać wyświetlona strona, zamień ją na call to 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)