01
$.ajax({
02
type:
"POST"
,
03
contentType:
"application/json"
,
04
url: myurl,
05
<font color=
"#ff0000"
>data</font>: {},
06
timeout: 30000,
//超时时间:30秒
07
dataType:
'json'
,
08
<font color=
"#ff0000"
>error</font>: function(XMLHttpRequest, textStatus, errorThrown){
09
},
10
success: function(result) {
11
// TODO: check result
12
}
13
});
error:function (XMLHttpRequest, textStatus, errorThrown) |
{ |
} |
(默认: 自己主动推断 (xml 或 html)) 请求失败时调用时间。參数有下面三个:XMLHttpRequest 对象、错误信息、(可选)捕获的错误对象。假设发生了错误,错误信息(第二个參数)除了得到 null 之外,还可能是 "timeout" , "error" , "notmodified" 和 "parsererror" 。 |
error事件返回的第一个參数XMLHttpRequest有一些实用的信息: XMLHttpRequest.readyState: 状态码 0 - (未初始化)还没有调用send()方法 1 - (加载)已调用send()方法,正在发送请求 2 - (加载完毕)send()方法运行完毕,已经接收到所有响应内容 3 - (交互)正在解析响应内容 4 - (完毕)响应内容解析完毕,能够在client调用了
XMLHttpRequest.status属性:一些错误代码:
data:"{}", data为空也一定要传"{}";不然返回的是xml格式的。并提示parsererror.
见juqery源代码:
01
httpData: function( xhr, type, s ) {
02
var ct = xhr.getResponseHeader(
"content-type"
) ||
""
,
03
xml = type ===
"xml"
|| !type && ct.indexOf(
"xml"
) >= 0,
04
data = xml ? xhr.responseXML : xhr.responseText;
05
06
if
( xml && data.documentElement.nodeName ===
"parsererror"
) {
07
jQuery.error(
"parsererror"
);
08
}
09
10
// Allow a pre-filtering function to sanitize the response
11
// s is checked to keep backwards compatibility
12
if
( s && s.dataFilter ) {
13
data = s.dataFilter( data, type );
14
}
15
16
// The filter can actually parse the response
17
if
(
typeof
data ===
"string"
) {
18
// Get the JavaScript object, if JSON is used.
19
if
( type ===
"json"
|| !type && ct.indexOf(
"json"
) >= 0 ) {
20
data = jQuery.parseJSON( data );
21
22
// If the type is "script", eval it in global context
23
}
else
if
( type ===
"script"
|| !type && ct.indexOf(
"javascript"
) >= 0 ) {
24
jQuery.globalEval( data );
25
}
26
}
27
28
return
data;
29
},
会发现 parsererror的异常和 Header 类型也有关系。及编码 |
1
header(
'Content-type: text/html; charset=utf8'
);
附 |
Technorati 标签:
XMLHttpRequest.status
1xx-信息提示 这些状态代码表示暂时的响应。client在收到常规响应之前,应准备接收一个或多个1xx响应。 100-继续。 101-切换协议。 2xx-成功 这类状态代码表明server成功地接受了client请求。 200-确定。client请求已成功。 201-已创建。 202-已接受。 203-非权威性信息。 204-无内容。 205-重置内容。 206-部分内容。 3xx-重定向 client浏览器必须採取很多其它操作来实现请求。比如,浏览器可能不得不请求server上的不同的页面,或通过代理server反复该请求。 301-对象已永久移走,即永久重定向。 302-对象已暂时移动。 304-未改动。 307-暂时重定向。 4xx-client错误 错误发生,client似乎有问题。比如,client请求不存在的页面,client未提供有效的身份验证信息。400-错误的请求。 401-訪问被拒绝。IIS定义了很多不同的401错误,它们指明更为详细的错误原因。这些详细的错误代码在浏览器中显示,但不在IIS日志中显示: 401.1-登录失败。 401.2-server配置导致登录失败。 401.3-因为ACL对资源的限制而未获得授权。 401.4-筛选器授权失败。 401.5-ISAPI/CGI应用程序授权失败。 401.7–訪问被Webserver上的URL授权策略拒绝。这个错误代码为IIS6.0所专用。 403-禁止訪问:IIS定义了很多不同的403错误,它们指明更为详细的错误原因: 403.1-运行訪问被禁止。 403.2-读訪问被禁止。 403.3-写訪问被禁止。 403.4-要求SSL。 403.5-要求SSL128。 403.6-IP地址被拒绝。 403.7-要求client证书。 403.8-网站訪问被拒绝。 403.9-用户数过多。 403.10-配置无效。 403.11-password更改。 403.12-拒绝訪问映射表。 403.13-client证书被吊销。 403.14-拒绝文件夹列表。 403.15-超出client訪问许可。 403.16-client证书不受信任或无效。 403.17-client证书已过期或尚未生效。 403.18-在当前的应用程序池中不能运行所请求的URL。这个错误代码为IIS6.0所专用。 403.19-不能为这个应用程序池中的client运行CGI。这个错误代码为IIS6.0所专用。 403.20-Passport登录失败。这个错误代码为IIS6.0所专用。 404-未找到。 404.0-(无)–没有找到文件或文件夹。 404.1-无法在所请求的port上訪问Web网站。 404.2-Web服务扩展锁定策略阻止本请求。 404.3-MIME映射策略阻止本请求。 405-用来訪问本页面的HTTP谓词不被同意(方法不被同意) 406-client浏览器不接受所请求页面的MIME类型。 407-要求进行代理身份验证。 412-前提条件失败。 413–请求实体太大。 414-请求URI太长。 415–不支持的媒体类型。 416–所请求的范围无法满足。 417–运行失败。 423–锁定的错误。 5xx-server错误 server因为遇到错误而不能完毕该请求。 500-内部server错误。 500.12-应用程序正忙于在Webserver上又一次启动。 500.13-Webserver太忙。 500.15-不同意直接请求Global.asa。 500.16–UNC授权凭据不对。这个错误代码为IIS6.0所专用。 500.18–URL授权存储不能打开。这个错误代码为IIS6.0所专用。 500.100-内部ASP错误。 501-页眉值指定了未实现的配置。 502-Webserver用作网关或代理server时收到了无效响应。 502.1-CGI应用程序超时。 502.2-CGI应用程序出错。application. 503-服务不可用。这个错误代码为IIS6.0所专用。 504-网关超时。 505-HTTP版本号不受支持。 FTP 1xx-肯定的初步答复 这些状态代码指示一项操作已经成功開始,但client希望在继续操作新命令前得到还有一个答复。 110又一次启动标记答复。 120服务已就绪,在nnn分钟后開始。 125数据连接已打开,正在開始传输。 150文件状态正常,准备打开数据连接。 2xx-肯定的完毕答复 一项操作已经成功完毕。client能够运行新命令。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-肯定的中间答复 该命令已成功,但server须要很多其它来自client的信息以完毕对请求的处理。331username正确,须要password。 332须要登录帐户。 350请求的文件操作正在等待进一步的信息。 4xx-瞬态否定的完毕答复 该命令不成功,但错误是临时的。假设client重试命令,可能会运行成功。421服务不可用,正在关闭控制连接。假设服务确定它必须关闭,将向不论什么命令发送这一应答。 425无法打开数据连接。 426Connectionclosed;transferaborted. 450未运行请求的文件操作。文件不可用(比如,文件繁忙)。 451请求的操作异常终止:正在处理本地错误。 452未运行请求的操作。系统存储空间不够。 5xx-永久性否定的完毕答复 该命令不成功,错误是永久性的。假设client重试命令,将再次出现相同的错误。500语法错误,命令无法识别。这可能包含诸如命令行太长之类的错误。 501在參数中有语法错误。 502未运行命令。 503错误的命令序列。 504未运行该參数的命令。 530未登录。 532存储文件须要帐户。 550未运行请求的操作。文件不可用(比如,未找到文件,没有訪问权限)。 551请求的操作异常终止:未知的页面类型。 552请求的文件操作异常终止:超出存储分配(对于当前文件夹或数据集)。 553未运行请求的操作。不同意的文件名称。 常见的FTP状态代码及其原因 150-FTP使用两个port:21用于发送命令,20用于发送数据。状态代码150表示server准备在port20上打开新连接,发送一些数据。 226-命令在port20上打开数据连接以运行操作,如传输文件。该操作成功完毕,数据连接已关闭。 230-client发送正确的password后,显示该状态代码。它表示用户已成功登录。 331-client发送username后,显示该状态代码。不管所提供的username是否为系统中的有效帐户,都将显示该状态代码。 426-命令打开数据连接以运行操作,但该操作已被取消,数据连接已关闭。 530-该状态代码表示用户无法登录,由于username和password组合无效。假设使用某个用户帐户登录,可能键入错误的username或password,也可能选择仅仅同意匿名訪问。假设使用匿名帐户登录,IIS的配置可能拒绝匿名訪问。 550-命令未被运行,由于指定的文件不可用。比如,要GET的文件并不存在,或试图将文件PUT到您没有写入权限的文件夹。