簡體   English   中英

通過JSON將復雜對象發布到MVC Web API

[英]Posting Complex Objects through JSON to MVC Web API

我知道這是可能的,因為我一直都在使用其他API。 我遇到的問題是,當我發布以下JSON時,相關子對象ICollection變為空。 對於我做錯了任何幫助,將不勝感激。 這是我的對象:

public class PartsExpressOrder
{
    [Key]
    public int OrderId { get; set; }
    public int CustomerId { get; set; }
    public DateTime? OrderDate { get; set; }
    public double SubTotal { get; set; }
    public double Freight { get; set; }
    public double Taxes { get; set; }
    public double Total { get; set; }
    public string OrderStatus { get; set; }
    public string CompanyName { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string Phone { get; set; }
    public string Email { get; set; }
    public string ShipToName { get; set; }
    public string ShipToAddress { get; set; }
    public string ShipToCity { get; set; }
    public string ShipToState { get; set; }
    public string ShipToZip { get; set; }
    public string ShipToPhone { get; set; }
    public string BillToName { get; set; }
    public string BillToAddress { get; set; }
    public string BillToCity { get; set; }
    public string BillToState { get; set; }
    public string BillToZip { get; set; }

    public virtual ICollection<PartsExpressOrderItem> PartsExpressOrderItems { get; set; }
}

public class PartsExpressOrderItem
{
    [Key]
    public int OrderItemId { get; set; }
    public int OrderId { get; set; }
    public int MasterPartId { get; set; }
    public string Description { get; set; }
    public int Quantity { get; set; }
    public double Price { get; set; }
    public double Total { get; set; }
}

這是我通過JSON發布的內容:

{
  "CustomerId": 1,
  "OrderDate": "2018-07-01",
  "SubTotal": 65.68,
  "Freight": 15.00,
  "Taxes": 5.00,
  "Total": 85.68,
  "OrderStatus": "Sent",
  "CompanyName": "Test Company A",
  "FirstName": "Bob",
  "LastName": "Dobalina",
  "Phone": "5035551212",
  "Email": "bdobalina@testcompanya.com",
  "ShipToName": "Bob Dobalina",
  "ShipToAddress": "5512 Test Company A Blvd. Suite 503",
  "ShipToCity": "Seattle",
  "ShipToState": "WA",
  "ShipToZip": "98103",
  "ShipToPhone": "5035551212",
  "BillToName": null,
  "BillToAddress": null,
  "BillToCity": null,
  "BillToState": null,
  "BillToZip": null,
"PartsExpressOrderItem":
[{
  "MasterPartId": 1,
  "Description": "Widget",
  "Quantity": 2,
  "Price": 20.34,
  "Total": 40.68
},
{
  "MasterPartId": 2,
  "Description": "Sprocket",
  "Quantity": 5,
  "Price": 5.00,
  "Total": 25.00
}]
}

最后是我的控制器:

 // POST: api/PartsExpressOrders
    [ResponseType(typeof(PartsExpressOrder))]
    public IHttpActionResult PostPartsExpressOrder(PartsExpressOrder partsExpressOrder)
    {
        if (!ModelState.IsValid)
        {
            return BadRequest(ModelState);
        }

        db.PartsExpressOrder.Add(partsExpressOrder);
        db.SaveChanges();

        foreach(var item in partsExpressOrder.PartsExpressOrderItems)
        {
            item.OrderId = partsExpressOrder.OrderId;
            db.PartsExpressOrderItem.Add(item);
            db.SaveChanges();
        }

        return CreatedAtRoute("DefaultApi", new { id = partsExpressOrder.OrderId }, partsExpressOrder);
    }

您的ICollection<PartsExpressOrderItem> PartsExpressOrderItems所使用的json表示無效。 它看起來應該像這樣:

"PartsExpressOrderItems" : [
    { 
        "MasterPartId": 2,
        "Description": "Sprocket",
        "Quantity": 5,
         "Price": 5.00,
         "Total": 25.00
    },
    { 
        "MasterPartId": 3,
        "Description": "Something",
        "Quantity": 10,
         "Price": 12.00,
         "Total": 47.00
    }
]

除非您實現了自定義序列化方案,否則json表示形式和C#之間的名稱必須匹配(即:需要使用PartsExpressOrderItems作為鍵而不是PartsExpressOrderItem )。 另外,您正在查看的C#屬性是一個ICollection因此您需要利用json數組,而不是使用相同的鍵放入多個對象

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM