我有一个像下面这样的类,它被添加到项目/解决方案作为参考
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而异。驱动的课程是即时创建的。
请帮我解决这个问题
答案 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();