注册 | 登陆
您的位置:阿里西西 > 前端技术 > 脚本技术 > 详细内容

ajax post data 获取不到数据,注意content-type的设置post/get

  稿源:互联网   2014-03-11 14:08:59   点击:   撤稿纠错

以下讨论的是和相关的ajax post data 获取不到数据,注意content-type的设置post/get 教程文章,内容是本站精心挑选整理的教程,希望对广大的网友给到帮助,下面是详细内容:

  ajax post  data  获取不到数据,注意 content-type的设置 、post/get
关于 jQuery data 传递数据。网上各种获取不到数据,乱码之类的。
好吧今天我也遇到了,网上一查各种纠结。乱码不管先看获取不到数据。
因为之前一直用jQuery ajax get的方式传递参数, 默认没有设置过 contentType 的值。

      var Skip = 49; //Number of skipped row
     var Take = 14; //
     function Load(Skip, Take) {
          $('#divPostsLoader').html('');
         //send a query to server side to present new content
         $.ajax({
              type: "get",
              url: "AjaxImage.ashx",
             data: { Skip: Skip, Take: Take },
              //contentType: "application/json; charset=utf-8",//(可以)
             //contentType: "text/xml",//(可以)
              //contentType:"application/x-www-form-urlencoded",//(可以)
             //dataType: "string",
              success: function (data) {
                  if (data != "") {
                     $('.thumb').append(data);
                  }
                 $('#divPostsLoader').empty();
              }
          })
     };

chrome下,没有设置contentType的值,好,我们来看默认情况:

image

默认参数通过url参数传递,请求的内容类型:application/x-www-form-urlencoded

一般处理文件获取参数内容:

int Skip = Convert.ToInt32(context.Request["Skip"]); 2: int Take = Convert.ToInt32(context.Request["Take"]);

毫无压力,因为我一直都是这么干的大笑,没有任何问题。好了,来换一下请求的内容类型:
 //contentType: "application/json; charset=utf-8",//(可以) 2: //contentType: "text/xml",//(可以)
 

也都可以,参数获取正常。
这也就是我们说的get方式,参数是跟在url后边,与Content-Type无关。

 

可是今天要用post方式了有木有。

$.ajax({ 2: type: "post",
chrome下,没有设置contentType的值,来看默认情况:

image

 

data数据由from表单提交,请求的内容类型:application/x-www-form-urlencoded,

好了,默认情况下一般处理文件获取参数也可以。

可是,但是 我最开始设置的是 contentType: "application/json; charset=utf-8",看图:

image

Request Paload 是什么???

调试一下,看我们的from里边,没有内容:

image

好吧, 到这里我们解决了 博问里那个问题(http://q.cnblogs.com/q/11342/),

本来搜索到这个博问,甚是高兴的,但是,悬而未决有木有,小伙伴不厚道啊!捧腹大笑

经测试:

              //contentType: "application/json; charset=utf-8",//(不可以)
              //contentType: "text/xml",//(不可以)
             contentType:"application/x-www-form-urlencoded",//(可以)

 

总结一下吧:本来get/post方式都是知道的,但注意,contentType与传递数据匹配(本文data)。

            做过模拟登录、模拟提交数据的同学肯定都很清楚了。


关于ajax post data 获取不到数据,注意content-type的设置post/get的内容写到这里就结束啦,您可以收藏本页网址http://www.alixixi.com/web/ a/2014031192641.shtml方便下次再访问哦。