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)