JsonSerializer不序列化派生类属性

时间:2015-07-02 12:39:17

标签: c# .net servicestack servicestack-text

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

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)类是有条件加载的,其属性也可能因condion而异。驱动的课程是即时创建的。

请帮我解决这个问题

1 个答案:

答案 0 :(得分:1)

首先inheritance in DTO's should be avoided,如果必须使用它,那么你应该创建基类abstract,以便ServiceStack Serializer知道何时发出动态类型信息。

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

var json = JsonSerializer.SerializeToString(result);

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

var json = result.ToJson();