jQuery和ExtJS的timeOut超時問題和event事件處理問題

来源:http://www.cnblogs.com/dingjiaoyang/archive/2016/02/22/5207976.html
-Advertisement-
Play Games

對jQuery來說,超時可以直接設置timeout參數,併在error事件中捕獲第二個參數,如果是“timeout”則表明捕獲了超時事件,非常清楚。 例子: $.ajax({ type: "POST", contentType: "application/json", url: "../ws/MyS


對jQuery來說,超時可以直接設置timeout參數,併在error事件中捕獲第二個參數,如果是“timeout”則表明捕獲了超時事件,非常清楚。 

例子: 

$.ajax({ 
        type: "POST", 
        contentType: "application/json", 
        url: "../ws/MyService.asmx/test", 
        data: '{"email":"'+email+'"}', 
        timeout: 30000, //超時時間:30秒 
        dataType: 'json', 
        error: function(XMLHttpRequest, textStatus, errorThrown){ 
        //TODO: 處理status, http status code,超時 408 
        // 註意:如果發生了錯誤,錯誤信息(第二個參數)除了得到null之外,還可能 
              //是"timeout", "error", "notmodified" 和 "parsererror"。 
        }, 
        success: function(result) { 
          // TODO: check result 
        } 
});                

另外,error事件返回的第一個參數XMLHttpRequest有一些有用的信息: 
XMLHttpRequest.readyState: 狀態碼 
  0 - (未初始化)還沒有調用send()方法 
  1 - (載入)已調用send()方法,正在發送請求 
  2 - (載入完成)send()方法執行完成,已經接收到全部響應內容 
  3 - (交互)正在解析響應內容 
  4 - (完成)響應內容解析完成,可以在客戶端調用了 
XMLHttpRequest.status屬性:一些錯誤代碼 
HTTP  
1xx-信息提示  
這些狀態代碼表示臨時的響應。客戶端在收到常規響應之前,應準備接收一個或多個1xx響應。  
100-繼續。  
101-切換協議。  
2xx-成功  
這類狀態代碼表明伺服器成功地接受了客戶端請求。  
200-確定。客戶端請求已成功。  
201-已創建。  
202-已接受。  
203-非權威性信息。  
204-無內容。  
205-重置內容。  
206-部分內容。  
3xx-重定向  
客戶端瀏覽器必須採取更多操作來實現請求。例如,瀏覽器可能不得不請求伺服器上的不同的頁面,或通過代理伺服器重覆該請求。  
301-對象已永久移走,即永久重定向。  
302-對象已臨時移動。  
304-未修改。  
307-臨時重定向。  
4xx-客戶端錯誤  
發生錯誤,客戶端似乎有問題。例如,客戶端請求不存在的頁面,客戶端未提供有效的身份驗證信息。400-錯誤的請求。  
401-訪問被拒絕。IIS定義了許多不同的401錯誤,它們指明更為具體的錯誤原因。這些具體的錯誤代碼在瀏覽器中顯示,但不在IIS日誌中顯示:  
401.1-登錄失敗。  
401.2-伺服器配置導致登錄失敗。  
401.3-由於ACL對資源的限制而未獲得授權。  
401.4-篩選器授權失敗。  
401.5-ISAPI/CGI應用程式授權失敗。  
401.7–訪問被Web伺服器上的URL授權策略拒絕。這個錯誤代碼為IIS6.0所專用。  
403-禁止訪問:IIS定義了許多不同的403錯誤,它們指明更為具體的錯誤原因:  
403.1-執行訪問被禁止。  
403.2-讀訪問被禁止。  
403.3-寫訪問被禁止。  
403.4-要求SSL。  
403.5-要求SSL128。  
403.6-IP地址被拒絕。  
403.7-要求客戶端證書。  
403.8-站點訪問被拒絕。  
403.9-用戶數過多。  
403.10-配置無效。  
403.11-密碼更改。  
403.12-拒絕訪問映射表。  
403.13-客戶端證書被吊銷。  
403.14-拒絕目錄列表。  
403.15-超出客戶端訪問許可。  
403.16-客戶端證書不受信任或無效。  
403.17-客戶端證書已過期或尚未生效。  
403.18-在當前的應用程式池中不能執行所請求的URL。這個錯誤代碼為IIS6.0所專用。  
403.19-不能為這個應用程式池中的客戶端執行CGI。這個錯誤代碼為IIS6.0所專用。  
403.20-Passport登錄失敗。這個錯誤代碼為IIS6.0所專用。  
404-未找到。  
404.0-(無)–沒有找到文件或目錄。  
404.1-無法在所請求的埠上訪問Web站點。  
404.2-Web服務擴展鎖定策略阻止本請求。  
404.3-MIME映射策略阻止本請求。  
405-用來訪問本頁面的HTTP謂詞不被允許(方法不被允許)  
406-客戶端瀏覽器不接受所請求頁面的MIME類型。  
407-要求進行代理身份驗證。  
412-前提條件失敗。  
413–請求實體太大。  
414-請求URI太長。  
415–不支持的媒體類型。  
416–所請求的範圍無法滿足。  
417–執行失敗。  
423–鎖定的錯誤。  
5xx-伺服器錯誤  
伺服器由於遇到錯誤而不能完成該請求。  
500-內部伺服器錯誤。  
500.12-應用程式正忙於在Web伺服器上重新啟動。  
500.13-Web伺服器太忙。  
500.15-不允許直接請求Global.asa。  
500.16–UNC授權憑據不正確。這個錯誤代碼為IIS6.0所專用。  
500.18–URL授權存儲不能打開。這個錯誤代碼為IIS6.0所專用。  
500.100-內部ASP錯誤。  
501-頁眉值指定了未實現的配置。  
502-Web伺服器用作網關或代理伺服器時收到了無效響應。  
502.1-CGI應用程式超時。  
502.2-CGI應用程式出錯。application.  
503-服務不可用。這個錯誤代碼為IIS6.0所專用。  
504-網關超時。  
505-HTTP版本不受支持。  
FTP  
1xx-肯定的初步答覆  
這些狀態代碼指示一項操作已經成功開始,但客戶端希望在繼續操作新命令前得到另一個答覆。  
110重新啟動標記答覆。  
120服務已就緒,在nnn分鐘後開始。  
125數據連接已打開,正在開始傳輸。  
150文件狀態正常,準備打開數據連接。  
2xx-肯定的完成答覆  
一項操作已經成功完成。客戶端可以執行新命令。200命令確定。  
202未執行命令,站點上的命令過多。  
211系統狀態,或系統幫助答覆。  
212目錄狀態。  
213文件狀態。  
214幫助消息。  
215NAME系統類型,其中,NAME是AssignedNumbers文檔中所列的正式系統名稱。  
220服務就緒,可以執行新用戶的請求。  
221服務關閉控制連接。如果適當,請註銷。  
225數據連接打開,沒有進行中的傳輸。  
226關閉數據連接。請求的文件操作已成功(例如,傳輸文件或放棄文件)。  
227進入被動模式(h1,h2,h3,h4,p1,p2)。  
230用戶已登錄,繼續進行。  
250請求的文件操作正確,已完成。  
257已創建“PATHNAME”。  
3xx-肯定的中間答覆  
該命令已成功,但伺服器需要更多來自客戶端的信息以完成對請求的處理。331用戶名正確,需要密碼。  
332需要登錄帳戶。  
350請求的文件操作正在等待進一步的信息。  
4xx-瞬態否定的完成答覆  
該命令不成功,但錯誤是暫時的。如果客戶端重試命令,可能會執行成功。421服務不可用,正在關閉控制連接。如果服務確定它必須關閉,將向任何命令發送這一應答。  
425無法打開數據連接。  
426Connectionclosed;transferaborted.  
450未執行請求的文件操作。文件不可用(例如,文件繁忙)。  
451請求的操作異常終止:正在處理本地錯誤。  
452未執行請求的操作。系統存儲空間不夠。  
5xx-永久性否定的完成答覆  
該命令不成功,錯誤是永久性的。如果客戶端重試命令,將再次出現同樣的錯誤。500語法錯誤,命令無法識別。這可能包括諸如命令行太長之類的錯誤。  
501在參數中有語法錯誤。  
502未執行命令。  
503錯誤的命令序列。  
504未執行該參數的命令。  
530未登錄。  
532存儲文件需要帳戶。  
550未執行請求的操作。文件不可用(例如,未找到文件,沒有訪問許可權)。  
551請求的操作異常終止:未知的頁面類型。  
552請求的文件操作異常終止:超出存儲分配(對於當前目錄或數據集)。  
553未執行請求的操作。不允許的文件名。  
常見的FTP狀態代碼及其原因  
150-FTP使用兩個埠:21用於發送命令,20用於發送數據。狀態代碼150表示伺服器準備在埠20上打開新連接,發送一些數據。  
226-命令在埠20上打開數據連接以執行操作,如傳輸文件。該操作成功完成,數據連接已關閉。  
230-客戶端發送正確的密碼後,顯示該狀態代碼。它表示用戶已成功登錄。  
331-客戶端發送用戶名後,顯示該狀態代碼。無論所提供的用戶名是否為系統中的有效帳戶,都將顯示該狀態代碼。  
426-命令打開數據連接以執行操作,但該操作已被取消,數據連接已關閉。  
530-該狀態代碼表示用戶無法登錄,因為用戶名和密碼組合無效。如果使用某個用戶帳戶登錄,可能鍵入錯誤的用戶名或密碼,也可能選擇只允許匿名訪問。如果使用匿名帳戶登錄,IIS的配置可能拒絕匿名訪問。  
550-命令未被執行,因為指定的文件不可用。例如,要GET的文件並不存在,或試圖將文件PUT到您沒有寫入許可權的目錄。 

ExtJS的預設超時時間是30s,超過就會ajax請求失敗,http status code 408。 

設置ExtJS的超時時間方法需要用Ext.data.Connection 對象,並捕捉requestexception事件,例子: 



var conn=new Ext.data.Connection({ 
    url: "../ws/MyService.asmx/test", 
    timeout : 60000, //自定義超時時間,這裡是60秒 (預設30s) 
    autoAbort : false, 
    disableCaching : true , 
    method : "GET" 
}); 

var proxy = new Ext.data.HttpProxy(conn); 

proxy.getConnection().on("requestcomplete", function(sender, response, options){    
    //成功,response.status = 200, response.statusText = 'OK' 
}); 

proxy.getConnection().on("requestexception", function(sender, response, options){ 
    //異常,捕捉 esponse.status  ( http status code 代碼 )和 response.statusText 
}); 
    
var store = new Ext.data.Store({ 
    proxy: proxy, 
    reader: myReader, //需要另外定義一個reader 
    baseParams: {myargument:'myargumentValue'}, //改成你的參數名和值 
    remoteSort: false 
});    

store.load();


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 紅色:熱情、奔放、喜悅、莊嚴 黃色:高貴、富有、燦爛、活潑 黑色:嚴肅、夜晚、沉著 白色:純潔、簡單、潔凈 藍色:天空、清爽、科技 綠色:植物、生命、生機 灰色:莊重、沉穩 紫色:爛漫、富貴 棕色:大地、厚朴
  • 怎樣把一個DIV放到另一個div右下角??? 藉助CSS定位來實現,你將右下角的那個DIV放在另一個DIV裡面,參考代碼如下示: <div id="box1"> <div id="box2">測試內容</div> </div> <style> <!-- #box1{width:600px;heigh
  • [1]關鍵字 [2]16進位 [3]rgb [4]rgba [5]hsl [6]hsla
  • HTML 用兩個空格來代替製表符(tab) -- 這是唯一能保證在所有環境下獲得一致展現的方法。 嵌套元素應當縮進一次(即兩個空格) 對於屬性的定義,確保全部使用雙引號,絕不要使用單引號。 不要在自閉合(self-closing)元素的尾部添加斜線 -- HTML5 規範中明確說明這是可選的。 不要
  • 傳統的JavaScript註重用函數和基於原型的繼承來創建可復用的組件,但這可能讓用習慣面對對象方式的程式員感到棘手,因為他們的繼承和創建對象都是由類而來的。從JavaScript的下一個版本,ECMAScript 6開始,JavaScript程式員就能夠用基於這種基於類的面對對象方式來創建編寫自己
  • 對isPrototypeOf和getPrototypeOf兩個方法,通過例子進行了簡要的講解。
  • 最近我初學HTML5,剛在一步步學習SVG,積累了一些個人心得和程式代碼,希望和大家分享,今天分享“svg之矩形”部分 1、簡單矩形 效果圖如下: 關鍵代碼: <svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <rect width="30
  • 以下寫法:沒有明確指定module和controller,寫法不規範. 更改angular.js版本會出bug. 1 <html ng-app> 2 <head> 3 <title>1.0.1-1.5版本間的差異</title> 4 <script src="/js/angular-1.0.1.mi
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...