加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 00:29:58 所属栏目:百科 来源:网络整理
导读: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 传递数据。网上各种获取不到数据,乱

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",//(可以)
 
   
也都可以,参数获取正常。
这也就是我们说的get方式,参数是跟在url后边,与Content-Type无关。
 
  
可是今天要用post方式了有木有。
 
    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)。
            做过模拟登录、模拟提交数据的同学肯定都很清楚了。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读