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)