我知道您不喜欢包装器的想法,但是有一个解决方案在某种程度上使用了包装器,但也使用了非常易于使用的 xml 属性。我拒绝使用以下方法是使用旧的序列化程序。
public class Product
{
[XmlAttribute( "id" )]
public int Id
{
get;
set;
}
[XmlAttribute( "name" )]
public string Name
{
get;
set;
}
[XmlAttribute( "quantity" )]
public int Quantity
{
get;
set;
}
}
[XmlRoot( "Products" )]
public class Products
{
[XmlAttribute( "nid" )]
public int Id
{
get;
set;
}
[XmlElement(ElementName = "Product")]
public List<Product> AllProducts { get; set; }
}
现在您的控制器可以返回以下产品:
public Products Get()
{
return new Products
{
AllProducts = new List<Product>
{
new Product {Id = 1, Name = "Product1", Quantity = 20},
new Product {Id = 2, Name = "Product2", Quantity = 37},
new Product {Id = 3, Name = "Product3", Quantity = 6},
new Product {Id = 4, Name = "Product4", Quantity = 2},
new Product {Id = 5, Name = "Product5", Quantity = 50},
}
};
}
现在您可以像这样在启动时指定序列化程序:
var productssXmlFormatter = GlobalConfiguration.Configuration.Formatters.XmlFormatter;
productssXmlFormatter.SetSerializer<Products>( new XmlSerializer( typeof( Products ) ) );
我知道这不是必须指定序列化程序并失去 EF 和 Linq 的灵活性和便利性的最理想方式。或者至少必须进行干预,而不仅仅是返回 IEnumerable<>。
当我第一次从以下站点了解到这种方式时,我必须感谢以下站点:http: //justthisguy.co.uk/outputting-custom-xml-net-web-api/
这将产生以下 xml:
<Products nid="0">
<Product id="1" name="Product1" quantity="20"/>
<Product id="2" name="Product2" quantity="37"/>
<Product id="3" name="Product3" quantity="6"/>
<Product id="4" name="Product4" quantity="2"/>
<Product id="5" name="Product5" quantity="50"/>
</Products>
请不要忘记查看列出的站点。