码迷,mamicode.com
首页 > Web开发 > 详细

Jquery Ajax时 error处理 之 parsererror

时间:2014-08-15 22:27:19      阅读:405      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   java   使用   os   io   

   
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 标签:
 
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到您没有写入权限的文件夹。

 

Jquery Ajax时 error处理 之 parsererror,布布扣,bubuko.com

Jquery Ajax时 error处理 之 parsererror

标签:style   blog   http   color   java   使用   os   io   

原文地址:http://www.cnblogs.com/hrhguanli/p/3915673.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!