Jquery Ajax时 error处理 之 parsererror

Jquery Ajax时 error处理 之 parsererror

   
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,布布扣,bubuko.com

时间: 2024-10-04 22:42:32

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

IE6下jquery ajax报error的原因

用jquery ajax()方法,在其他浏览都通过,IE7以上都通过,唯独在ie6不行. 我这边的解决方案是:必须保证ajax里面的所有数字为小写,ie6对大小写敏感. 错误: $.ajax({ url:'update.req', data:data, Type:'post', dataType:'JSON', cache:false, success:function(data){ if (data.ret==0) { window.location = "get.req"; } e

jquery Ajax应用总结

常见应用: 下面是Jquery中AJAX参数详细列表: 参数名 类型 描述 url String (默认: 当前页地址) 发送请求的地址. type String (默认: "GET") 请求方式 ("POST" 或 "GET"), 默认为 "GET".注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持. timeout Number 设置请求超时时间(毫秒).此设置将覆盖全局设置.

jQuery.ajax(url,[settings])

概述 通过 HTTP 请求加载远程数据. jQuery 底层 AJAX 实现.简单易用的高层实现见 $.get, $.post 等.$.ajax() 返回其创建的 XMLHttpRequest 对象.大多数情况下你无需直接操作该函数,除非你需要操作不常用的选项,以获得更多的灵活性. 最简单的情况下,$.ajax()可以不带任何参数直接使用. 注意,所有的选项都可以通过$.ajaxSetup()函数来全局设置. 回调函数 如果要处理$.ajax()得到的数据,则需要使用回调函数.beforeSen

Java程序员之JS(一) 之 JQuery.ajax

背景:紧着现在项目的需要,先从JQuery.ajax出发,主要需求是通过 js 调用Java 代码,从而适应现在的项目. 先从几个概念开始讲解: 一. 什么是Deferred  Deferred 对象是由.Deferred构造的, .Deferred被实现为简单工厂模式.它是用来解决JS中的异步编程,遵循 Common Promise/A规范,实现此规范的还有when.js 和 dojo. Deferred 对象在 JQuery 1.5被引入,用来解决 Ajax 异步优化问题,正是由于 Defe

JQuery AJAX $.ajax()方法

AJAX = Asynchronous JavaScript and XML. AJAX 是一种创建快速动态网页的技术. AJAX 通过在后台与服务器交换少量数据的方式,允许网页进行异步更新.这意味着有可能在不重载整个页面的情况下,对网页的一部分进行更新. JQuery脚本库里所提供的AJAX提交的方法有很多,但主要的方法有$.get(),$.post(),$.ajax().其中$.ajax()是前两种方法的底层实现,可以提供比前两者更多的属性与参数设置,如果需要高级的设置使用,建议使用$.aj

jquery Ajax中的dataType简析

jquery中的ajax有好几种运用方式,但是基本上都是使用的$.ajax()方法,很多人经常会使用它来从后台获取json格式的数据,但是经常发现返回的json字符串并不能自动的转换成js里的json对象. 为什么呢?主要是因为$.ajax()方法的参数没有正确的设置, 其中我们需要重点关注的是dataType参数,这个配置决定了jquery如何帮助我们自动解析服务器返回的数据,有几种方式可以获取后台返回的json字符串并解析为json对象,下面是asp.net为例解释: 1.$.ajax()参

jQuery.ajax() 函数详解

jQuery.ajax()函数用于通过后台HTTP请求加载远程数据. jQuery.ajax()函数是jQuery封装的AJAX技术实现,通过该函数,我们无需刷新当前页面即可获取远程服务器上的数据. jQuery.ajax()函数是jQuery的底层AJAX实现.jQuery.get(). jQuery.post().load(). jQuery.getJSON(). jQuery.getScript()等函数都是该函数的简化形式(都调用该函数,只是参数设置有所不同或有所省略). 该函数属于全局

jQuery.ajax相关

jQuery.ajax(url,[settings]) 通过 HTTP 请求加载远程数据. jQuery 底层 AJAX 实现.简单易用的高层实现见 $.get, $.post 等.$.ajax() 返回其创建的 XMLHttpRequest 对象.大多数情况下你无需直接操作该函数,除非你需要操作不常用的选项,以获得更多的灵活性. 最简单的情况下,$.ajax()可以不带任何参数直接使用. 注意,所有的选项都可以通过$.ajaxSetup()函数来全局设置. 回调函数 如果要处理$.ajax()

jQuery ajax - ajax() 方法详解

一些代码通过jQuery来做ajax异步提交. //验证昵称是否存在 function checkNickNameIsExist(){ var nickName = jQuery("#nickName").val(); var flag = false; jQuery.ajax( { url: "checkNickName?t=" + (new Date()).getTime(), data:{nickName:nickName}, dataType:"j