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)