Flask重定向和錯誤

Flask類有重定向redirect()函數。調用時,它會返回一個響應對象,並將用戶重定向到具有指定狀態碼的另一個目標位置。

redirect()函數的原型如下 -

Flask.redirect(location, statuscode, response)

在上述函數中 -

  • location 參數是響應應該被重定向的URL。
  • statuscode 參數發送到瀏覽器的頭標,默認爲302
  • response 參數用於實例化響應。

以下狀態代碼是標準化的 -

  • 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

默認狀態碼是302,這是表示’找到’頁面。

在以下示例中,redirect()函數用於在登錄嘗試失敗時再次顯示登錄頁面。

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'))
    return redirect(url_for('index'))

@app.route('/success')
def success():
    return 'logged in successfully'

if __name__ == '__main__':
    app.run(debug = True)

Flask類具有帶有錯誤代碼的abort()函數。

Flask.abort(code)

code參數使用以下值之一 -

  • 400 - 對於錯誤的請求
  • 401 - 用於未經身份驗證
  • 403 - 禁止
  • 404 - 未找到
  • 406 - 不可接受
  • 415 - 用於不支持的媒體類型
  • 429 - 請求過多

這裏對上面的代碼中的login()函數進行一些細微的修改。 如果要顯示「Unauthourized」頁面,而不是重新顯示登錄頁面,請將其替換爲中止(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)