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

Jquery Ajax时 error处理 之 parsererror的更多相关文章

  1. IE6下jquery ajax报error的原因

    用jquery ajax()方法,在其他浏览都通过,IE7以上都通过,唯独在ie6不行. 我这边的解决方案是:必须保证ajax里面的所有数字为小写,ie6对大小写敏感. 错误: $.ajax({ ur ...

  2. jquery ajax中error返回错误解决办法

    转自:https://www.jb51.net/article/72198.htm 进入百度搜索此问题,发现有人这么说了一句 Jquery中的Ajax的async默认是true(异步请求),如果想一个 ...

  3. jquery ajax的error错误信息

    项目开发中ajax的异常处理起来算是比较头疼的,因为是异步请求,所以即使ajax异常程序依然会继续执行,导致找ajax的异常比较麻烦. 今天处理ajax异常时搜到一篇文章,提到error可以返回aja ...

  4. jquery Ajax应用总结

    常见应用: 下面是Jquery中AJAX参数详细列表: 参数名 类型 描述 url String (默认: 当前页地址) 发送请求的地址. type String (默认: "GET&quo ...

  5. jQuery.ajax(url,[settings])

    概述 通过 HTTP 请求加载远程数据. jQuery 底层 AJAX 实现.简单易用的高层实现见 $.get, $.post 等.$.ajax() 返回其创建的 XMLHttpRequest 对象. ...

  6. jQuery.ajax() 函数详解

    jQuery.ajax()函数用于通过后台HTTP请求加载远程数据. jQuery.ajax()函数是jQuery封装的AJAX技术实现,通过该函数,我们无需刷新当前页面即可获取远程服务器上的数据. ...

  7. JQuery $.ajax()方法详解

    jQuery Ajax 参考手册 实例 通过 AJAX 加载一段文本: jQuery 代码: $(document).ready(function(){ $("#b01").cli ...

  8. AJAX和jQuery Ajax总结

    AJAX全称为“Asynchronous JavaScript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用,改善用户体验,实现无刷新效果的技术. 使用AJAX的优 ...

  9. jquery Ajax中的dataType简析

    jquery中的ajax有好几种运用方式,但是基本上都是使用的$.ajax()方法,很多人经常会使用它来从后台获取json格式的数据,但是经常发现返回的json字符串并不能自动的转换成js里的json ...

随机推荐

  1. UVa1225 Digit Counting

    #include <stdio.h>#include <string.h> int main(){    int T, N, i, j;    int a[10];    sc ...

  2. poj2032Square Carpets(IDA* + dancing links)

    题目请戳这里 题目大意:给一个H行W列的01矩阵,求最少用多少个正方形框住所有的1. 题目分析:又是一个红果果的重复覆盖模型.DLX搞之! 枚举矩阵所有的子正方形,全1的话建图.判断全1的时候,用了一 ...

  3. pcap文件格式解析

    pcap文件格式是常用的数据报存储格式,包括wireshark在内的主流抓包软件都可以生成这种格式的数据包 下面对这种格式的文件简单分析一下:    pcap文件的格式为:  文件头    24字节  ...

  4. Spring RESTful服务接收和返回JSON最佳实践

    http://blog.csdn.net/prince_hua/article/details/12103501

  5. PSAM卡

    PSAM卡    终端安全控制模块,符合<中国金融集成电路(IC卡)PSAM卡规范>,   包括普通PSAM卡和高速PSAM卡. PSAM符合以下标准及规范: 识别卡,带触点的集成电路卡标 ...

  6. Protel99se轻松入门:特殊技巧和高级设置(一)

    这里简单介绍一下自动布线和手动布线方面的设置问题 1.如何进入PCB的这个布线规则选项: 2.电气安全距离的设置 3.导线宽度的设置 4.学会了设置图层就可以做单面板以及多层板,而不只是双面板 5.布 ...

  7. QT 自动获取可用串口

    本来想直接用Settings来获取的,但是串口信息类似 "\Device\Serial0",死活获取不了,用了转义.反斜杠还是获取不到,所以就放弃了,网上好像也没有获取成功的. 所 ...

  8. HDU 1568 Fibonacci

    题解:首先,对于小于10000的斐波那契数,我们直接计算,当大于10000时,用公式,由于只要输出前四位,所以不用考虑浮点数的问题,算出其取log的结果: tmp=(log(sq5/5)+n*log( ...

  9. hdoj 1532 Drainage Ditches(最大网络流)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 思路分析:问题为最大网络流问题,给定一个有向图,需要求解该有向图的最大网络流,使用Edmonds ...

  10. Ants(思维)

    Ants Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 12893   Accepted: 5637 Description ...