ajax post data 获取不到数据,注意 content-type的设置 、post/get
2013-11-26 19:56:44
cnblogs.com-
Vincent Liu-
点击数:654
ajax post data 获取不到数据,注意 content-type的设置 、post/get
关于 jQuery data 传递数据。网上各种获取不到数据,乱码之类的。
好吧今天我也遇到了,网上一查各种纠结。乱码不管先看获取不到数据。
因为之前一直用jQuery ajax get的方式传递参数,默认没有设置过contentType的值。
1: var Skip = 49; //Number of skipped row
2: var Take = 14; //
3: function Load(Skip,Take) {
4: $('#divPostsLoader').html('<img src="ProgressBar/ajax-loader.gif">');
5: //send a query to server side to present new content
6: $.ajax({
7: type: "get",
8: url: "AjaxImage.ashx",
9: data: { Skip: Skip,Take: Take },
10: //contentType: "application/json; charset=utf-8",//(可以)
11: //contentType: "text/xml",//(可以)
12: //contentType:"application/x-www-form-urlencoded",//(可以)
13: //dataType: "string",
14: success: function (data) {
15: if (data != "") {
16: $('.thumb').append(data);
17: }
18: $('#divPostsLoader').empty();
19: }
20: })
21: };
chrome下,没有设置contentType的值,好,我们来看默认情况:
单击看大图
默认参数通过url参数传递,请求的内容类型:application/x-www-form-urlencoded
1:
intSkip = Convert.ToInt32(context.Request["Skip"]);
2:intTake = Convert.ToInt32(context.Request["Take"]);
毫无压力,因为我一直都是这么干的,没有任何问题。好了,来换一下请求的内容类型:
1://contentType: "application/json; charset=utf-8",//(可以)
2://contentType:"text/xml",//(可以)
1:$.ajax({
2:type:"post",
chrome下,没有设置contentType的值,来看默认情况:
单击看图
data数据由from表单提交,请求的内容类型:application/x-www-form-urlencoded,
可是,但是我最开始设置的是contentType: "application/json; charset=utf-8",看图:
单击看图
Request Paload 是什么???
调试一下,看我们的from里边,没有内容:
单击看图
好吧, 到这里我们解决了 博问里那个问题(http://q.cnblogs.com/q/11342/),
本来搜索到这个博问,甚是高兴的,但是,悬而未决有木有,小伙伴不厚道啊!
经测试:
1: //contentType: "application/json; charset=utf-8",//(不可以)
2: //contentType: "text/xml",//(不可以)
3: contentType:"application/x-www-form-urlencoded",//(可以)
总结一下吧:本来get/post方式都是知道的,但注意,contentType与传递数据匹配(本文data)。
做过模拟登录、模拟提交数据的同学肯定都很清楚了。