我正在使用.NET 3.5中的DataContractSerializer来反序列化xml。 xml之前是从实体模型中的一组相关实体序列化的,由实体框架3.5支持。有许多引用,xml广泛包含每个引用实体的成员和键的所有值。
顶级实体反序列化很好,但引用的实体没有。
这是我用来序列化和反序列化的代码:
public static T DCDeserializeXml<T>(string xml)
{
MemoryStream memoryStream = new MemoryStream(Encoding.Unicode.GetBytes(xml));
using (
XmlDictionaryReader reader = XmlDictionaryReader.CreateTextReader(memoryStream, Encoding.Unicode,
new XmlDictionaryReaderQuotas(), null))
{
DataContractSerializer dataContractSerializer = new DataContractSerializer(typeof(T), null, Int32.MaxValue, false, true, null);
return (T)dataContractSerializer.ReadObject(reader, true);
}
}
public static string DCSerializeToXml<T>(T obj)
{
DataContractSerializer dataContractSerializer = new DataContractSerializer(typeof(T), null, Int32.MaxValue, false, true, null);
String text;
using (MemoryStream memoryStream = new MemoryStream())
{
dataContractSerializer.WriteObject(memoryStream, obj);
byte[] data = new byte[memoryStream.Length];
Array.Copy(memoryStream.GetBuffer(), data, data.Length);
text = Encoding.UTF8.GetString(data);
}
return text;
}
这是XML的片段:
<?xml version="1.0" encoding="utf-8"?>
<Assets>
<Asset z:Id="i1" xmlns="http://schemas.datacontract.org/2004/07/XLayer" xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns:z="http://schemas.microsoft.com/2003/10/Serialization/">
<EntityKey z:Id="i2" xmlns="http://schemas.datacontract.org/2004/07/System.Data.Objects.DataClasses" xmlns:a="http://schemas.datacontract.org/2004/07/System.Data">
<a:EntityContainerName>XModelContainer</a:EntityContainerName>
<a:EntityKeyValues>
<a:EntityKeyMember>
<a:Key>AssetGUID</a:Key>
<a:Value i:type="z:guid">7424f615-43db-4834-b15a-5befa46bfd55</a:Value>
</a:EntityKeyMember></a:EntityKeyValues>
<a:EntitySetName>AssetSet</a:EntitySetName>
</EntityKey>
<AssetGUID>7424f615-43db-4834-b15a-5befa46bfd55</AssetGUID>
<Created>2011-06-23T13:34:12.893</Created>
<Description/>
<npAudioInfoReference xmlns:a="http://schemas.datacontract.org/2004/07/System.Data.Objects.DataClasses">
<a:EntityKey i:nil="true" xmlns:b="http://schemas.datacontract.org/2004/07/System.Data"/>
</npAudioInfoReference>
<npCampaigns/>
<npCategory z:Id="i3">
<EntityKey z:Id="i4" xmlns="http://schemas.datacontract.org/2004/07/System.Data.Objects.DataClasses" xmlns:a="http://schemas.datacontract.org/2004/07/System.Data">
<a:EntityContainerName>XModelContainer</a:EntityContainerName>
<a:EntityKeyValues>
<a:EntityKeyMember>
<a:Key>CategoryID</a:Key>
<a:Value i:type="b:int" xmlns:b="http://www.w3.org/2001/XMLSchema">1</a:Value>
</a:EntityKeyMember>
</a:EntityKeyValues>
<a:EntitySetName>AssetCategorySet</a:EntitySetName>
</EntityKey>
<AM_DataDocumentTypes/>
<CategoryID>1</CategoryID>
<CategoryName>Generic Content</CategoryName>
<npAssets>
我已经被困在这几天了,我已经用尽了所有能找到的搜索结果。使用这种技术可以清楚地避免在我们的模型中为每个实体类型编写大量代码,其中有143个。
重申一下,顶级实体反序列化很好,但引用的实体却没有。因此,在反序列化之后,资产被加载并且Asset.AssetCategory(以及更多)解析为null,我需要帮助来修复它,以便所有引用都被实例化。请有人吗?
答案 0 :(得分:2)
有时你需要告诉序列化器其他“已知类型”。
请参阅MSDN文档:
http://msdn.microsoft.com/en-us/library/ms730167.aspx
您可以通过配置,通过属性或通过DataContractSerializer上的参数/属性来执行此操作。
这里有文档链接的完整示例: