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. 【转】Linq实现DataTable行列转换

    出处:http://www.cnblogs.com/li-peng/ 转换前的table: 转换后的table: 代码里有详细的说明, 还有一些参数我都截图了下面有 using System;usin ...

  2. iOS网络请求基础

    这篇是关于网络请求的,结合公司的实际情况编写,如果有不同意见欢迎留言共同讨论. iOS在9.0之后彻底放弃了NSURLConnection,现在已经改用了NSURLSession进行网络请求.一般现在 ...

  3. [Jobdu] 题目1517:链表中倒数第k个结点

    给出一个链表的头指针,要求找到倒数第k个节点,并输出这个节点的值 例子: 先看一个例子,链表为:1 2 3 4 5 6,倒数第2个节点就是5,倒数第一个节点就是6,以此类推.这里的链表有头节点,就是说 ...

  4. Problem E: Automatic Editing

    Problem E: Automatic EditingTime Limit: 1 Sec Memory Limit: 128 MBSubmit: 3 Solved: 3[Submit][Status ...

  5. 搜索(BFS)

    Problem B: Fire! Joe works in a maze. Unfortunately, portions of the maze have caught on fire, and t ...

  6. bzoj 1057: [ZJOI2007]棋盘制作 单调栈

    题目链接 1057: [ZJOI2007]棋盘制作 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 2027  Solved: 1019[Submit] ...

  7. idea中使用scala运行spark出现Exception in thread "main" java.lang.NoClassDefFoundError: scala/collection/GenTraversableOnce$class

    idea中使用scala运行spark出现: Exception in thread "main" java.lang.NoClassDefFoundError: scala/co ...

  8. Mac OS X Mavericks or Yosemite 安装Nginx、PHP、Mysql、phpMyAdmin

    翻译:http://blog.frd.mn/install-nginx-php-fpm-mysql-and-phpmyadmin-on-os-x-mavericks-using-homebrew/ 最 ...

  9. C++ 用libcurl库进行http 网络通讯编程

      一.LibCurl基本编程框架libcurl是一个跨平台的网络协议库,支持http, https, ftp, gopher, telnet, dict, file, 和ldap 协议.libcur ...

  10. [置顶] js操作iframe兼容各种浏览器

    在做项目时,遇到了操作iframe的相关问题.业务很简单,其实就是在操作iframe内部某个窗体时,调用父窗体的一个函数.于是就写了两个很简单的htm页面用来测试,使用网上流行的方法在谷歌浏览器中始终 ...