JsonSerializer未序列化派生类属性

本文关键字:属性 派生 序列化 JsonSerializer | 更新日期: 2023-09-27 18:00:53

我有一个类似下面的类,它被添加到项目/解决方案中作为参考

public class FileContents
{
    public List<RecordBase> Records { get; set; }
}
public class RecordBase
{
    public int LineNumber { get; set; }
}

很少有其他类没有添加到引用中,而是动态加载的,这些类是从RecordBase类派生的,下面是如何加载的片段

var fileContents = new FileContents();
var dll = Assembly.LoadFile(derivedClassesAssemblyLocation);
Type type = dll.GetExportedTypes().Where(a =>  
                           a.Name.Equals(className)).FirstOrDefault();
if (type != null && type.Name == className)
{
    dynamic instance = Activator.CreateInstance(type);
    //All properties are populated to the instance
    //.....
    //.....
    fileContents.Records.Add(instance)
}

下面是前面提到的其他类,它们是从RecordBase 派生的

public class RecordStyleA : RecordBase
{
    public string PropertyA { get; set; }
    public string PropertyB { get; set; }
    public string PropertyC { get; set; }
}

加载和序列化

 var result = new FileContents();
 //Logic to load ....
 var serializer = new ServiceStack.Text.JsonStringSerializer();
 var json = serializer.SerializeToString(result);

在这里,当我尝试序列化FileContents对象时,它跳过了派生类中可用的属性(例如RecordStyleA(

这里Derived(RecordStyleA(类是有条件加载的,其属性也可能因条件而异。驱动类是动态创建的。

请帮助我解决这个问题

JsonSerializer未序列化派生类属性

首先,应避免DTO中的继承,如果必须使用它,则应将基类设为abstract,以便ServiceStack Serializer知道何时发出动态类型信息。

请注意,用于序列化为JSON的两个最常见的API是使用静态JsonSerializer类,例如:

var json = JsonSerializer.SerializeToString(result);

或者.ToJson()/.FromJson()扩展方法,例如:

var json = result.ToJson();