随笔分类 - AJAX

Posted 悦码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了随笔分类 - AJAX相关的知识,希望对你有一定的参考价值。

$.ajax返回的JSON格式的数据后无法执行success的解决方法

  近段时间做项目,在项目使用了ajax技术,遇到了一个奇怪的问题:"$.ajax返回的JSON格式的数据无法执行success",代码是这样写的: 1 $.ajax({

 2 .. 
 3 dataType:'json', 
 4 ... 
 5 success:function(jsonData){ 
 6 //不执行success  7 }, 
 8 error:function(error){ 
 9 //总是执行这个error 10 } 
11 });

  百思不得其解啊,为什么会这样子呢?检查了一下返回的JSON字符串,我觉得JSON字符串的格式应该没有问题的,于是在网上查了一下,发现有还真有人遇到了和我一样的问题,找出原因所在"是因为我指定了dataType:'json',这样指定之后,对Json格式的要求就非常严格起来了,起初我的json格式是这样写的:"{result:{\"success\":\"true\",\"meg\":\"success\"}}",可这样写不行,得改成这样写:"{\"success\":true,\"mesg\":\"success\"}",如果说是bool类型,则不用加引号,其它的键/值都需要加引号。jquery 1.4以后对json格式变严格了,也就是说必须要这种格式的{"键":"值","键":"值"};像原来的{键:值,键:值}和{'键':'值','键':'值'}这种都是错误的,不合标准,所以jquery返回error。以前没有注意到这样的问题,这次遇到了,也找到了解决办法,在此记录一下!

ashx文件获取$.ajax()方法发送的数据

今天在使用Jquery的ajax方法发送请求时,发现在后台中使用ashx文件无法接收到ajax方法中传递的参数,上网查了一下原因后发现了问题所在,原来是我在$.ajax方法中指明了"contentType: 'application/json; charset=utf8'",所以才导致了在ashx文件中处理请求时无法获取传递到服务器端的参数

正确的写法如下:

1 $.ajax({ 2             url: '/Handler1.ashx?operFlag=test1', 3             type: 'POST', 4             /* 5            请求ashx文件的时候 要把contentType去掉,还有就是 6            data 格式为 {”key”,”value”};切记 不要再 大括号外面加双引号, 7            这样就会在ashx页面取不到数据而失败 8             */ 9             //contentType: 'application/json; charset=utf8',10            data: {11                 "key1": "xdp",12                 "key2":"孤傲苍狼"

13             },14             cache: false,15             dataType: 'text',16             success: function (data) {17                 alert(data);18             },19             error: function (xhr) {20                 alert("出现错误,请稍后再试:" + xhr.responseText);21             }22         });



这样在ashx文件中就可以使用如下的代码来获取$.ajax方法传递的参数了,代码如下:

1  string key1 = context.Request["key1"];2  string key2 = context.Request["key2"];

以前一直都是用$.post方法来处理ajax,所以没有注意到这个问题,而这次由于是项目需要,所以就使用了$.ajax,没想到就遇到了上述的问题,好在找出了问题所在并且及时解决了问题。

另外,最近还遇到了一个奇怪的问题,"用ajax提交数据到ashx后,用JSON.stringify格式化参数后在服务器端取不到值?",代码如下:

1 $.ajax({ 2             url: '/Handler1.ashx?operFlag=test2', 3             type: 'POST', 4             //JSON.stringify格式化参数 5            data: JSON.stringify({ 6                 "key3": "xdp-gacl", 7                 "key4": "白虎神皇" 8            }), 9             contentType: 'application/json; charset=utf8',10             cache: false,11             dataType: 'json',12             success: function (data) {13                 alert(data.key3 + "|" + data.key4);14            },15             error: function (xhr) {16                 alert("出现错误,请稍后再试:" + xhr.responseText);17            }18         });结果在ashx中使用context.Request["key3"]这种常规的方式是获取不到参数的,如下图所示:

郁闷了好久,怎么也想不明白为什么会这样,一开始以为是多了contentType: 'application/json; charset=utf8'这句代码造成的,于是把这句代码注释掉:


1 $.ajax({ 2             url: '/Handler1.ashx?operFlag=test2', 3             type: 'POST', 4             //JSON.stringify格式化参数 5            data: JSON.stringify({ 6                 "key3": "xdp-gacl", 7                 "key4": "白虎神皇" 8            }), 9             //contentType: 'application/json; charset=utf8',10             cache: false,11             dataType: 'json',12             success: function (data) {13                 alert(data.key3 + "|" + data.key4);14            },15             error: function (xhr) {16                 alert("出现错误,请稍后再试:" + xhr.responseText);17            }18         });


可是结果还是一样的,使用context.Request["key3"]还是获取不到参数,没办法,既然常规的方式获取不到,那就另寻他法吧,百度了一下,找到了解决办法,在ashx中使用如下的方式就可以获取到了,首先写一个通用的获取参数的方法,代码如下:

1         /// <summary> 2         /// 获取参数 3         /// </summary> 4         /// <param name="context"></param> 5         /// <returns></returns> 6         private Dictionary<String, Object> GetParameter(HttpContext context) 7        { 8             StreamReader reader = new StreamReader(context.Request.InputStream); 9             //得到json字符串:strJson={"key3":"xdp-gacl","key4":"白虎神皇"}10             String strJson = HttpUtility.UrlDecode(reader.ReadToEnd());11             javascriptSerializer jss = new JavaScriptSerializer();12             //将json字符串反序列化成一个Dictionary对象13             Dictionary<String, Object> dicParameter = jss.Deserialize<Dictionary<String, Object>>(strJson);14             return dicParameter;15         }

GetParameter方法返回一个dicParameter对象,dicParameter就存放了从$.ajax方法中提交到ashx中的参数,如下图所示:

这样就可以从dicParameter中取出传递过来的参数作处理了,完整代码如下: 1  public void ProcessRequest(HttpContext context) 2        { 3             context.Response.ContentType = "text/plain"; 4             string operFlag = context.Request["operFlag"]; 5             if (operFlag == "test1") 6            { 7                 string key1 = context.Request["key1"]; 8                 string key2 = context.Request["key2"]; 9                 string resStr = key1 + "|" + key2;10                context.Response.Write(resStr);11            }12             else if (operFlag == "test2")13            {14                 Dictionary<String, Object> dicParameter = GetParameter(context);15                 string key3 = dicParameter["key3"].ToString();16                 string key4 = dicParameter["key4"].ToString();17                 string resStr = "{\"key3\":\"" + key3 + "\", \"key4\":\"" + key4 + "\"}";18                context.Response.Write(resStr);19            }20 21         } 


以上是关于随笔分类 - AJAX的主要内容,如果未能解决你的问题,请参考以下文章

7-11随笔

AJAX相关JS代码片段和部分浏览器模型

感知器代码实现--机器学习随笔2

AJAX学习随笔

随笔分类

随笔分类 - [C#6] 新增特性