天天看點

jquery ajax 錯誤調試

下面是Jquery中AJAX參數詳細清單:

參數名 類型 描述
url String (預設: 目前頁位址) 發送請求的位址。
type String (預設: "GET") 請求方式 ("POST" 或 "GET"), 預設為 "GET"。注意:其它 HTTP 請求方法,如 PUT 和 DELETE 也可以使用,但僅部分浏覽器支援。
timeout Number 設定請求逾時時間(毫秒)。此設定将覆寫全局設定。
async Boolean (預設: true) 預設設定下,所有請求均為異步請求。如果需要發送同步請求,請将此選項設定為 false。注意,同步請求将鎖住浏覽器,使用者其它操作必須等待請求完成才可以執行。
beforeSend Function 發送請求前可修改 XMLHttpRequest 對象的函數,如添加自定義 HTTP 頭。XMLHttpRequest 對象是唯一的參數。
function (XMLHttpRequest) {
  this; // the options for this ajax request
}      
cache Boolean (預設: true) jQuery 1.2 新功能,設定為 false 将不會從浏覽器緩存中加載請求資訊。
complete Function 請求完成後回調函數 (請求成功或失敗時均調用)。參數: XMLHttpRequest 對象,成功資訊字元串。
function (XMLHttpRequest, textStatus) {
  this; // the options for this ajax request
}      
contentType String (預設: "application/x-www-form-urlencoded") 發送資訊至伺服器時内容編碼類型。預設值适合大多數應用場合。
data

Object,

String

發 送到伺服器的資料。将自動轉換為請求字元串格式。GET 請求中将附加在 URL 後。檢視 processData 選項說明以禁止此自動轉換。必須為 Key/Value 格式。如果為數組,jQuery 将自動為不同值對應同一個名稱。如 {foo:["bar1", "bar2"]} 轉換為 '&foo=bar1&foo=bar2'。
dataType String

預期伺服器傳回的資料類型。如果不指定,jQuery 将自動根據 HTTP 包 MIME 資訊傳回 responseXML 或 responseText,并作為回調函數參數傳遞,可用值:

"xml": 傳回 XML 文檔,可用 jQuery 處理。

"html": 傳回純文字 HTML 資訊;包含 script 元素。

"script": 傳回純文字 JavaScript 代碼。不會自動緩存結果。

"json": 傳回 JSON 資料 。

"jsonp": JSONP 格式。使用 JSONP 形式調用函數時,如 "myurl?callback=?" jQuery 将自動替換 ? 為正确的函數名,以執行回調函數。

error Function (預設: 自動判斷 (xml 或 html)) 請求失敗時将調用此方法。這個方法有三個參數:XMLHttpRequest 對象,錯誤資訊,(可能)捕獲的錯誤對象。
function (XMLHttpRequest, textStatus, errorThrown) {
  // 通常情況下textStatus和errorThown隻有其中一個有值 
  this; // the options for this ajax request
}      
global Boolean (預設: true) 是否觸發全局 AJAX 事件。設定為 false 将不會觸發全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用于控制不同的Ajax事件
ifModified Boolean (預設: false) 僅在伺服器資料改變時擷取新資料。使用 HTTP 包 Last-Modified 頭資訊判斷。
processData Boolean (預設: true) 預設情況下,發送的資料将被轉換為對象(技術上講并非字元串) 以配合預設内容類型 "application/x-www-form-urlencoded"。如果要發送 DOM 樹資訊或其它不希望轉換的資訊,請設定為 false。
success Function 請求成功後回調函數。這個方法有兩個參數:伺服器傳回資料,傳回狀态
function (data, textStatus) {
  // data could be xmlDoc, jsonObj, html, text, etc...
  this; // the options for this ajax request
}      

代碼:$(document).ready(function() {

            jQuery("#clearCac").click(function() {

                jQuery.ajax({

                    url: "/Handle/Do.aspx",

                    type: "post",

                    data: { id: '0' },

                    dataType: "json",

                    success: function(msg) {

                        alert(msg);

                    },

                    error: function(XMLHttpRequest, textStatus, errorThrown) {

                        alert(XMLHttpRequest.status);

                        alert(XMLHttpRequest.readyState);

                        alert(textStatus);

                    },

                    complete: function(XMLHttpRequest, textStatus) {

                        this; // 調用本次AJAX請求時傳遞的options參數

                    }

                });

            });

        });

一、error:function (XMLHttpRequest, textStatus, errorThrown)

{

}

(默 認: 自動判斷 (xml 或 html)) 請求失敗時調用時間。參數有以下三個:XMLHttpRequest 對象、錯誤資訊、(可選)捕獲的錯誤對象。如果發生了錯誤,錯誤資訊(第二個參數)除了得到null之外,還可能是"timeout", "error", "notmodified" 和 "parsererror"。

textStatus:

 "timeout", "error", "notmodified" 和 "parsererror"。

二、error事件傳回的第一個參數XMLHttpRequest有一些有用的資訊:

XMLHttpRequest.readyState:

狀态碼 

0 - (未初始化)還沒有調用send()方法 

1 - (載入)已調用send()方法,正在發送請求 

2 - (載入完成)send()方法執行完成,已經接收到全部響應内容 

3 - (互動)正在解析響應内容 

4 - (完成)響應内容解析完成,可以在用戶端調用了

三、data:"{}", data為空也一定要傳"{}";不然傳回的是xml格式的。并提示parsererror.

四、parsererror的異常和Header 類型也有關系。及編碼header('Content-type: text/html; charset=utf8');

五、XMLHttpRequest.status:

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到您沒有寫入權限的目錄。

原文:http://mybloggers.blog.163.com/blog/static/1003865092010111631741468/