Rozwiązaliśmy to, tworząc niestandardowy formatator XML.
To nie jest idealne rozwiązanie, ale działa.
W Global.asax
GlobalConfiguration.Configuration.Formatters.Add(new CustomXmlFormatter());
GlobalConfiguration.Configuration.Formatters
.Remove(GlobalConfiguration.Configuration.Formatters.XmlFormatter);
Utwórz nową klasę o nazwie CustomXmlFormatter
using System;
using System.IO;
using System.Net.Http.Formatting;
using System.Net.Http.Headers;
using System.Threading.Tasks;
using Newtonsoft.Json;
namespace EMP.WebServices.api.Formatters
{
public class CustomXmlFormatter : MediaTypeFormatter
{
public CustomXmlFormatter()
{
SupportedMediaTypes.Add(
new MediaTypeHeaderValue("application/xml"));
SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/xml"));
}
public override bool CanReadType(Type type)
{
if (type == (Type)null)
throw new ArgumentNullException("type");
return true;
}
public override bool CanWriteType(Type type)
{
return true;
}
public override Task WriteToStreamAsync(Type type, object value,
Stream writeStream, System.Net.Http.HttpContent content,
System.Net.TransportContext transportContext)
{
return Task.Factory.StartNew(() =>
{
var json = JsonConvert.SerializeObject(value);
var xml = JsonConvert
.DeserializeXmlNode("{\"Root\":" + json + "}", "");
xml.Save(writeStream);
});
}
}
}
to fantastyczne rozwiązanie. Gwarantuje to, że jeśli korzystasz również z konwertera Jets Newtonsoft, zawsze kończysz z tymi samymi danymi, które są wyprowadzane przez oba formaty - bez konieczności zaznaczania wszystkich modeli. –
Proponuję dodanie parametru JsonMediaTypeFormatter do CustomXmlFormatter. Następnie, gdy wywołasz SerializeObject, przekaż JsonMediaTypeFormatter.SerializerSettings. Dzięki temu będziesz używać tych samych ustawień do tworzenia zarówno JSON, jak i XML. – Brian
Dla mnie jest to naprawdę eleganckie rozwiązanie tego problemu, o którym wspomina powyższy @Brian: chciałem, aby moje ustawienia JSON dostosowały się do typu mediów XML; dziękuję za podzielenie się tym podejściem, @Jakub! FWIW, zredagowałem odpowiedź z implementacją, którą ostatecznie zakończyłem z kontami typu "array" i kontami z możliwością deserializacji XML. –