[CollectionDataContract(Namespace = "http://schemas.datacontract.org/2004/07/ServicesTools.WebServices")]
public class AcquisitionDetails : List<Acquisition>
{
}
[DataContract(Name = "Acquisition", Namespace = "http://schemas.datacontract.org/2004/07/ServicesTools.WebServices")]
public class Acquisition
{
[DataMember]
public string GeoCode { get; set; }
[DataMember]
public string OrderDate { get; set; }
[DataMember]
public string Supplier { get; set; }
[DataMember]
public string PartNo { get; set; }
[DataMember]
public int QtyExpected { get; set; }
[DataMember]
public uint PONumber { get; set; }
}
in a different question, we got this XML working:
<?xml version="1.0" encoding="utf-8"?>
<AcquisitionDetails>
<Acquisition>
<GeoCode>PHX</GeoCode>
<OrderDate>3/10/2020 12:00:00 AM</OrderDate>
<PartNo>20L6S52C11</PartNo>
<QtyExpected>71</QtyExpected>
<PONumber>1990001996</PONumber>
<Supplier>Lenovo (International) BV</Supplier>
</Acquisition>
</AcquisitionDetails>
Code in the Controller:
[Consumes("application/xml")]
[Produces("application/xml")]
[HttpPost]
public ActionResult Post(AcquisitionDetails ad)
{
return Ok(ad);
}
BUT, there's a but;
when I sent this in POSTMAN, the PONumber for example, is empty
<AcquisitionDetails xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/ServicesTools.WebServices">
<Acquisition>
<GeoCode>PHX</GeoCode>
<OrderDate>3/10/2020 12:00:00 AM</OrderDate>
<PONumber>0</PONumber>
<PartNo>20L6S52C11</PartNo>
<QtyExpected>71</QtyExpected>
<Supplier>Lenovo (International) BV</Supplier>
</Acquisition>
</AcquisitionDetails>
This is the case, until I move it up a bit, but then
<Acquisition>
<GeoCode i:nil="true" />
<OrderDate i:nil="true" />
<PONumber>1990001996</PONumber>
<PartNo>20L6S52C11</PartNo>
<QtyExpected>71</QtyExpected>
<Supplier>Lenovo (International) BV</Supplier>
</Acquisition>
anyway, long story short.. I cannot change the sequence of the incoming XML, nor do I want to be forced to receive the XML in said sequence; how can I instruct the model to parse the XML as it comes?
========update=====
[DataContract(Name = "Acquisition", Namespace = "http://schemas.datacontract.org/2004/07/ServicesTools.WebServices")]
public class Acquisition
{
[DataMember(Name = "GeoCode")]
public string GeoCode { get; set; }
[DataMember(Name = "OrderDate")]
public string OrderDate { get; set; }
[DataMember(Name = "Supplier")]
public string Supplier { get; set; }
[DataMember(Name = "PartNo")]
public string PartNo { get; set; }
[DataMember(Name = "QtyExpected")]
public int QtyExpected { get; set; }
[DataMember(Name = "PONumber")]
public Int64 PONumber { get; set; }
}
but, the results are still:
Input:
<?xml version="1.0" encoding="utf-8"?>
<AcquisitionDetails xmlns="http://schemas.datacontract.org/2004/07/ServicesTools.WebServices">
<Acquisition>
<GeoCode>PHX</GeoCode>
<OrderDate>3/10/2020 12:00:00 AM</OrderDate>
<PONumber>1990001996</PONumber>
<PartNo>20L6S52C11</PartNo>
<QtyExpected>71</QtyExpected>
<Supplier>Lenovo (International) BV</Supplier>
</Acquisition>
<Acquisition>
<GeoCode>PHX</GeoCode>
<OrderDate>3/9/2020 12:00:00 AM</OrderDate>
<PartNo>AA549668</PartNo>
<QtyExpected>20</QtyExpected>
<PONumber>1990001879</PONumber>
<Supplier>SHI INTERNATIONAL CORP</Supplier>
</Acquisition>
</AcquisitionDetails>
Output:
<AcquisitionDetails xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/ServicesTools.WebServices">
<Acquisition>
<GeoCode>PHX</GeoCode>
<OrderDate>3/10/2020 12:00:00 AM</OrderDate>
<PONumber>1990001996</PONumber>
<PartNo>20L6S52C11</PartNo>
<QtyExpected>71</QtyExpected>
<Supplier>Lenovo (International) BV</Supplier>
</Acquisition>
<Acquisition>
<GeoCode>PHX</GeoCode>
<OrderDate>3/9/2020 12:00:00 AM</OrderDate>
<PONumber>0</PONumber>
<PartNo>AA549668</PartNo>
<QtyExpected>20</QtyExpected>
<Supplier>SHI INTERNATIONAL CORP</Supplier>
</Acquisition>
</AcquisitionDetails>