zoukankan      html  css  js  c++  java
  • ajax post data 获取不到数据,注意 contenttype的设置 、post/get

       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的值,好,我们来看默认情况:

    image单击看大图

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

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

       1:  
    int Skip = Convert.ToInt32(context.Request["Skip"]); 2: int Take = 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的值,来看默认情况:
    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/),

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

    经测试:

       1:              //contentType: "application/json; charset=utf-8",//(不可以)
       2:              //contentType: "text/xml",//(不可以)
       3:              contentType:"application/x-www-form-urlencoded",//(可以)
     
    总结一下吧:本来get/post方式都是知道的,但注意,contentType与传递数据匹配(本文data)。
                做过模拟登录、模拟提交数据的同学肯定都很清楚了。
  • 相关阅读:
    分享一个安装PE到硬盘的软件
    [转]盘点谷歌旗下的那些逆天机器人(视频)
    ubuntu安装google 输入法
    Beyond Compare 3.3.8 build 16340 + Key
    don't panic !
    Python3 list sort排序
    《操作系统、预防进程死锁的银行家算法》
    《操作系统_时间片轮转RR进程调度算法》
    《操作系统_FCFS和SJF》
    Hive初步使用、安装MySQL 、Hive配置MetaStore、配置Hive日志《二》
  • 原文地址:https://www.cnblogs.com/dayou123123/p/3443939.html
Copyright © 2011-2022 走看看