Flask框架學習--abort,errorhandler,異常處理


abort,errorhandler,異常處理

一.abort,異常拋出

  • abort(code):主動拋出異常狀態碼
  • 參數code:HTTP的錯誤狀態碼
  • 例如:abort(404)

二.errorhandler,異常捕獲

  • errorhandler(code_or_exception):用來監聽捕捉異常,然后返回自定義的頁面處理
  • 參數:code_or_exception – HTTP的錯誤狀態碼或指定異常

代碼演示:

from flask import Flask,abort app = Flask(__name__) @app.route('/game/<int:age>') def play_game(age): #異常拋出 abort(404) return "helloworld" #異常捕獲 @app.errorhandler(404) def page_not_found(e): print(e) return "找不到服務器資源,服務器搬家了" if __name__ == '__main__': app.run()

三.常見異常碼所代表的含義

100     Continue     繼續。客戶端應繼續其請求
101     Switching Protocols     切換協議。服務器根據客戶端的請求切換協議。只能切換到更高級的協議,例如,切換到HTTP的新版本協議
 
200     OK     請求成功。一般用於GET與POST請求
201     Created     已創建。成功請求並創建了新的資源
202     Accepted     已接受。已經接受請求,但未處理完成
203     Non-Authoritative Information     非授權信息。請求成功。但返回的meta信息不在原始的服務器,而是一個副本
204     No Content     無內容。服務器成功處理,但未返回內容。在未更新網頁的情況下,可確保瀏覽器繼續顯示當前文檔
205     Reset Content     重置內容。服務器處理成功,用戶終端(例如:瀏覽器)應重置文檔視圖。可通過此返回碼清除瀏覽器的   表單域
206     Partial Content     部分內容。服務器成功處理了部分GET請求
 
300     Multiple Choices     多種選擇。請求的資源可包括多個位置,相應可返回一個資源特征與地址的列表用於用戶終端(例如:   瀏覽器)選擇
301     Moved Permanently     永久移動。請求的資源已被永久的移動到新URI,返回信息會包括新的URI,瀏覽器會自動定向到新   URI。今后任何新的請求都應使用新的URI代替
302     Found     臨時移動。與301類似。但資源只是臨時被移動。客戶端應繼續使用原有URI
303     See Other     查看其它地址。與301類似。使用GET和POST請求查看
304     Not Modified     未修改。所請求的資源未修改,服務器返回此狀態碼時,不會返回任何資源。客戶端通常會緩存訪問過的資   源,通過提供一個頭信息指出客戶端希望只返回在指定日期之后修改的資源
305     Use Proxy     使用代理。所請求的資源必須通過代理訪問
306     Unused     已經被廢棄的HTTP狀態碼
307     Temporary Redirect     臨時重定向。與302類似。使用GET請求重定向
 
400     Bad Request     客戶端請求的語法錯誤,服務器無法理解
401     Unauthorized     請求要求用戶的身份認證
402     Payment Required     保留,將來使用
403     Forbidden     服務器理解請求客戶端的請求,但是拒絕執行此請求
404     Not Found     服務器無法根據客戶端的請求找到資源(網頁)。通過此代碼,網站設計人員可設置"您所請求的資源無法找   到"的個性頁面
405     Method Not Allowed     客戶端請求中的方法被禁止
406     Not Acceptable     服務器無法根據客戶端請求的內容特性完成請求
407     Proxy Authentication Required     請求要求代理的身份認證,與401類似,但請求者應當使用代理進行授權
408     Request Time-out     服務器等待客戶端發送的請求時間過長,超時
409     Conflict     服務器完成客戶端的PUT請求是可能返回此代碼,服務器處理請求時發生了沖突
410     Gone     客戶端請求的資源已經不存在。410不同於404,如果資源以前有現在被永久刪除了可使用410代碼,網站設計人員   可通過301代碼指定資源的新位置
411     Length Required     服務器無法處理客戶端發送的不帶Content-Length的請求信息
412     Precondition Failed     客戶端請求信息的先決條件錯誤
413     Request Entity Too Large     由於請求的實體過大,服務器無法處理,因此拒絕請求。為防止客戶端的連續請求,服務器可   能會關閉連接。如果只是服務器暫時無法處理,則會包含一個Retry-After的響應信息
414     Request-URI Too Large     請求的URI過長(URI通常為網址),服務器無法處理
415     Unsupported Media Type     服務器無法處理請求附帶的媒體格式
416     Requested range not satisfiable     客戶端請求的范圍無效
417     Expectation Failed     服務器無法滿足Expect的請求頭信息
 
500     Internal Server Error     服務器內部錯誤,無法完成請求
501     Not Implemented     服務器不支持請求的功能,無法完成請求
502     Bad Gateway     充當網關或代理的服務器,從遠端服務器接收到了一個無效的請求
503     Service Unavailable     由於超載或系統維護,服務器暫時的無法處理客戶端的請求。延時的長度可包含在服務器的Retry-    After頭信息中
504     Gateway Time-out     充當網關或代理的服務器,未及時從遠端服務器獲取請求
505     HTTP Version not supported     服務器不支持請求的HTTP協議的版本,無法完成處理



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM