>我有一个包装列表,看起来像这样:
[JsonObject(MemberSerialization.Fields)]
public class OrderManager : IEnumerable<Order>, ISerializable
{
public OrderManager()
{ }
private List<Order> orders = new List<Order>();
public void AddOrder(OrderInfo orderInfo)
{
// do the work of making an order object from an OrderInfo.
// Add the new order object to the private list of orders
// orders.Add(order);
}
public IEnumerator<Order> GetEnumerator()
{
return orders.GetEnumerator();
}
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
{
return orders.GetEnumerator();
}
public OrderManager(SerializationInfo info, StreamingContext context)
{
// do custom serialization work here (never gets hit)
}
public void GetObjectData(SerializationInfo info, StreamingContext context)
{
// do custom serialization work here (never gets hit)
}
}
我在客户类中包含字段实例,如下所示:
[JsonObject(MemberSerialization.Fields)]
public class Customer
{
public Customer()
{ }
private OrderManager _orders
= new OrderManager();
public OrderManager Orders
{
get { return _orders; }
set { _orders = value; }
}
}
我可以序列化客户,但忽略OrderManager
上的ISerializable
接口。如果我从OrderManager
中删除 JsonObject
属性(可能是阻止使用ISerializable
的原因),则OrderManager
被视为数组,ISerializable
接口仍被忽略。
我尝试使用ICollection
而不是IEnumerable
:JSON.NET 无法反序列化包装的集合
由于我的包装集合是 Order
类型,而我的 AddOrder
方法采用OrderInfo
,因此公开ICollection<Order>
并没有真正起作用。无论哪种方式,ISerializable
接口都被忽略了。
有什么解决方法吗?
更新
只是为了澄清我确实将忽略序列化接口设置为 false。
private JsonSerializer GetSerializer()
{
var serializer = new JsonSerializer();
serializer.TypeNameHandling = TypeNameHandling.Auto;
serializer.TypeNameAssemblyFormat = System.Runtime.Serialization.Formatters.FormatterAssemblyStyle.Simple;
var contractResolver = new DefaultContractResolver(true);
contractResolver.IgnoreSerializableAttribute = false;
contractResolver.IgnoreSerializableInterface = false;
serializer.ContractResolver = contractResolver;
serializer.PreserveReferencesHandling = PreserveReferencesHandling.All;
serializer.ReferenceLoopHandling = ReferenceLoopHandling.Ignore;
return serializer;
}
这个答案可能很晚,但是:
这是因为它会先检查IEnumerable
的继承,然后再检查ISerializable
的继承,因此它将使用 Enumerable 接口首先拉出对象。
您可以通过使用此覆盖实现自己的协定解析程序从DefaultContractResolver
继承来覆盖此行为:
protected override JsonContract CreateContract(Type objectType)
{
if (typeof(ISerializable).IsAssignableFrom(objectType))
return CreateISerializableContract(objectType);
return base.CreateContract(objectType);
}
最好使用一些更好的逻辑,但这在根目录下会导致实现ISerializable
的对象和IEnumerable
首先使用 ISerializedable 实现。