如何将json对象数组发布到web api

时间:2015-01-23 09:37:27

标签: c# jquery asp.net json asp.net-web-api

如何将JSON数组发布到Web API?它适用于单个对象。

这是我尝试过的,但控制器似乎正在返回0而不是预期的3

这是我的JSON:

var sc = [{
              "ID": "5",
              "Patient_ID": "271655b8-c64d-4061-86fc-0d990935316a",
              "Table_ID": "Allergy_Trns",
              "Checksum": "-475090533",
              "LastModified": "2015-01-22T20:08:52.013"
          },
          {
              "ID": "5",
              "Patient_ID": "271655b8-c64d-4061-86fc-0d990935316a",
              "Table_ID": "Allergy_Trns",
              "Checksum": "-475090533",
              "LastModified": "2015-01-22T20:08:52.013"
          },
          {
              "ID": "5",
              "Patient_ID": "271655b8-c64d-4061-86fc-0d990935316a",
              "Table_ID": "Allergy_Trns",
              "Checksum": "-475090533",
              "LastModified": "2015-01-22T20:08:52.013"
          }];           

AJAX电话:

$.ajax({
           url: urlString,
           type: 'POST',
           data: sc,
           dataType: 'json',
           crossDomain: true,
           cache: false,
           success: function (data) { console.log(data); }
        });

Web API控制器:

[HttpPost]
public string PostProducts([FromBody]List<SyncingControl> persons)
{
    return persons.Count.ToString(); // 0, expected 3
}

3 个答案:

答案 0 :(得分:17)

json Table_ID": "Allergy_Trns"中的错误应为"Table_ID": "Allergy_Trns"

缺少双引号。

<强>更新

您需要确保将参数发送为json,如下所示:

 $.ajax({
        url: urlString,
        type: 'POST',
        data: JSON.stringify(sc),
        dataType: 'json',
        contentType: 'application/json',
        crossDomain: true,
        cache: false,
        success: function (data) { console.log(data); }
    });

注意JSON.stringify(sc),@ ethbi在指定内容类型方面也是正确的。

屏幕抓取

**Screen grab**

答案 1 :(得分:2)

您必须将内容类型标头添加到ajax请求中,以便WebAPI能够理解请求并使用正确的格式化程序对数据进行反序列化:

&#13;
&#13;
$.ajax({
           url: urlString,
           type: 'POST',
           data: sc,
           dataType: 'json',
           contentType: "application/json",
           crossDomain: true,
           cache: false,
           success: function (data) { console.log(data); }
        });
&#13;
&#13;
&#13;

答案 2 :(得分:0)

您可以在 beforeSend 上设置内容类型,以确保您的json数据与您的服务器对象匹配

$.ajax({
        beforeSend: function (xhr) {
            xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
        },
           url: urlString,
           type: 'POST',
           data: sc,
           dataType: 'json',
           contentType: "application/json",
           crossDomain: true,
           cache: false,
           success: function (data) { console.log(data); }
        });