使用Web API控制器解析传入的JSON(来自javascript Ajax帖子)

时间:2016-02-08 19:35:29

标签: c# json ajax asp.net-web-api2 asp.net-mvc-5.2

我有以下脚本

<script>
    $(window).load(function () {
        var model = [
            {
                "reservation":
                {
                    "ticketId": "782274b8-10d9-444c-8f05-3117853e3ee0",
                    "clubId": 70656,
                    "courtNumber": 1,
                    "crud_name": "add",
                    "reservationtype_name": "toernooi"
                }
            }, 
            {
                "reservation":
                {
                    "ticketId": "782274b8-10d9-444c-8f05-3117853e3ee0",
                    "clubId": 70656,
                    "courtNumber": 1,
                    "crud_name": "update",
                    "reservationtype_name": "toernooi"
                }
            }
        ];
        alert(JSON.stringify(model));
        $.ajax({
            type: "POST",
            data: JSON.stringify(model),
            url: "http://localhost:59854/api/incomingapi",
            contentType: "application/json",
            dataType: 'json',
            success: function (result) { },
            error: function (errResult) { }
        });
    });
</script>

我有以下控制器

public string Post(HttpRequestMessage request)
{
    string jsonString1 = request.Content.ReadAsStringAsync().Result;
    JavaScriptSerializer json_serializer = new JavaScriptSerializer();
    var v1 = json_serializer.DeserializeObject("{ \"test\":\"some data\" }");
    var v2 = json_serializer.DeserializeObject(jsonString1);
    JObject jobj1 = JObject.Parse("{ \"test\":\"some data\" }");
    JObject jobj2 = JObject.Parse(jsonString1);
    return "";
}

v1jobj1用于测试。 jsonString1充满了值。 v2在运行时填充了值。

但是我只有4种方法

  • 等于()
  • GetHashCode()方法
  • 的GetType()
  • 的ToString()

在我输入代码时可用...

我必须将jsonString1中的值转换为类型保留的集合或某些我可以循环或使用linq的东西,但是当我尝试这样的值时,值不会得到填充(一切都为null或0)。

示例,下面我可以循环并使用linq但是没有填充值(0和0而不是70656和1):

var parsedVar = json_serializer.Deserialize<ICollection<ReservationModelForJson>>(jsonString1);
var clubId = parsedVar.First().clubId;//is 0 should be 70656
var courtNumber = parsedVar.First().courtNumber;//is 0 should be 1

任何人都可以解决这个问题?非常感谢!

public class ReservationModelForJson
{
    public string ticketId { get; set; }
    public int clubId { get; set; }
    public int courtNumber { get; set; }
    public string crud_name { get; set; }
    public string reservationtype_name { get; set; }
}

ANSWER /溶液

我在下面添加了这个课程

public class JsonBinder
{
    public ReservationModelForJson reservation { get; set; }
}

并将我的控制器改为

public string Post(IEnumerable<JsonBinder> reservations)
{
    int clubId = reservations.First().reservation.clubId;
    int courtNumber = reservations.First().reservation.courtNumber;
    return "tnkx!";
}

3 个答案:

答案 0 :(得分:2)

这是因为您的反序列化失败了。您尝试在服务器端反序列化的内容与您的json模型不匹配。目前您尝试反序列化具有属性名称保留的对象列表(这是具有预期属性的对象)。要修复,请按照以下方式重新编写json。

 var model = [
        {
                "ticketId": "782274b8-10d9-444c-8f05-3117853e3ee0",
                "clubId": 70656,
                "courtNumber": 1,
                "crud_name": "add",
                "reservationtype_name": "toernooi"
        }, 
        {
                "ticketId": "782274b8-10d9-444c-8f05-3117853e3ee0",
                "clubId": 70656,
                "courtNumber": 1,
                "crud_name": "update",
                "reservationtype_name": "toernooi"
        }
    ];

或者创建一个具有对象属性名称预留的类,该类具有预期的属性,ticketId,clubId等...

答案 1 :(得分:0)

试试这个:

json_serializer.Deserialize<List<ReservationModelForJson>>(jsonString1);

您的courtNumber属性属于reservation对象,例如您应该使用parsedVar.First().courtNumber;。在这种情况下ReservationModelForJson的结构很重要。

答案 2 :(得分:0)

这应该有效。而不是Post方法中的HttpRequestMessage参数,使用ReservationModelForJson的集合。此外,您可能需要删除JSON.stringify(模型),并传递模型。

public string Post(IEnumerable<ReservationModelForJson> reservations)
{
   //Now you can work with the reservations collection
   var firstRes = reservations.FirstOrDefault(); 
}