C# XmlSerializer-反映类型时出错

C# XmlSerializer-反映类型时出错,c#,.net,xml,serialization,.net-2.0,C#,.net,Xml,Serialization,.net 2.0,使用C#.NET 2.0,我有一个复合数据类,上面有[Serializable]属性。我正在创建一个XMLSerializer类,并将其传递给构造函数: XmlSerializer serializer = new XmlSerializer(typeof(DataClass)); 我得到一个例外,说: 反射类型出错 在数据类内部有另一个复合对象。这是否也需要有[Serializable]属性,或者通过将其放在顶部对象上,它是否递归地将其应用于内部的所有对象?查看您得到的内部异常。它将告诉您哪

使用C#.NET 2.0,我有一个复合数据类,上面有
[Serializable]
属性。我正在创建一个
XMLSerializer
类,并将其传递给构造函数:

XmlSerializer serializer = new XmlSerializer(typeof(DataClass));
我得到一个例外,说:

反射类型出错


在数据类内部有另一个复合对象。这是否也需要有
[Serializable]
属性,或者通过将其放在顶部对象上,它是否递归地将其应用于内部的所有对象?

查看您得到的内部异常。它将告诉您哪个字段/属性在序列化时遇到问题

通过使用属性修饰字段/属性,可以从xml序列化中排除字段/属性


XmlSerializer
不使用该属性,所以我怀疑这就是问题所在。

还请注意,您不能序列化用户界面控件,并且任何要传递到剪贴板上的对象都必须是可序列化的,否则就不能传递到其他进程。

序列化图中的所有对象都必须是可序列化的

由于
XMLSerializer
是一个黑盒,如果您想在序列化过程中进一步调试,请检查这些链接


< P>我也认为可序列化的属性必须在对象上,但是除非我是一个完整的NOOB(我在深夜编码会话的中间),下面的作品来自:


我可以想象XmlSerializer正在公共属性上使用反射。

请记住,序列化类必须具有默认(即无参数)构造函数。如果你根本没有构造器,那很好;但是,如果您有一个带参数的构造函数,则还需要添加默认构造函数。

还要注意,
XmlSerializer
无法序列化抽象属性。。请参阅我的问题(我已向其添加了解决方案代码)


我一直在使用
NetDataSerialiser
类进行序列化 我的域类


域类在客户端和服务器之间共享。

我发现.Net 2.0中的Dictionary类不能使用XML进行序列化,但在使用二进制序列化时可以很好地进行序列化


我找到了一份工作

如果需要处理特定属性(即字典或任何类),可以实现该接口,这将允许您以更详细的编码为代价获得更大的自由度

有一个有趣的例子,它展示了一种优雅的方式来实现“扩展”XmlSerializer的复杂方式


文章说,

IXmlSerializable包含在官方文档中,但文档声明它不打算用于公共用途,并且没有提供除此之外的任何信息。这表明开发团队希望保留修改、禁用甚至完全删除此扩展性挂钩的权利。然而,只要你愿意接受这种不确定性并应对未来可能发生的变化,你就没有理由不利用它

因此,我建议实现自己的
IXmlSerializable
类,以避免太多复杂的实现


…使用反射实现自定义的
XmlSerializer
类可能很简单。

我最近在添加新属性时在web引用分部类中得到了这一点。自动生成的类正在添加以下属性

    [System.Xml.Serialization.XmlElementAttribute(Order = XX)]

我需要在自动生成的序列中添加一个顺序比最后一个高的类似属性,这为我解决了这个问题。

我遇到了一个类似的问题,结果是序列化程序无法区分我拥有的两个同名类(一个是另一个的子类)。内部异常如下所示:

“类型BaseNamespace.Class1”和“BaseNamespace.SubNamespace.Class1”都使用来自命名空间“”的XML类型名称“Class1”。使用XML属性为类型指定唯一的XML名称和/或命名空间

其中BaseNamespace.SubNamespace.Class1是BaseNamespace.Class1的子类

我需要做的是向其中一个类(我添加到基类)添加一个属性:


注意:如果你有更多的类层,你也需要给它们添加一个属性。

我刚刚遇到了同样的错误,发现问题出在
IEnumerable
类型的属性上。似乎无法直接序列化
IEnumerable


相反,可以使用
List

我遇到过一种情况,一行中两个元素的顺序相同

[System.Xml.Serialization.XmlElementAttribute(IsNullable = true, Order = 0, ElementName = "SeriousInjuryFlag")]
。。。。一些代码

[System.Xml.Serialization.XmlElementAttribute(IsNullable = true, Order = 0, ElementName = "AccidentFlag")]

当我更改代码,使类中每个新属性的顺序递增1时,错误消失了。

我最常见的原因是:

 - the object being serialized has no parameterless constructor
 - the object contains Dictionary
 - the object has some public Interface members


我也有同样的问题,在我的例子中,对象有一个只读集合。集合必须实现Add方法才能序列化

到目前为止,我对这里描述的所有问题都有一个稍微不同的解决方案,所以对于任何未来的文明,这里都是我的

我声明了一个“time”数据类型,因为原始类型是
TimeSpan
,随后更改为
String

[System.Xml.Serialization.XmlElementAttribute(DataType="time", Order=3)]
但是,实际类型是字符串

public string TimeProperty {
    get {
        return this.timePropertyField;
    }
    set {
        this.timePropertyField = value;
        this.RaisePropertyChanged("TimeProperty");
    }
}
通过删除
DateType
属性,可以序列化
Xml

[System.Xml.Serialization.XmlElementAttribute(Order=3)]
public string TimeProperty {
    get {
        return this.timePropertyField;
    }
    set {
        this.timePropertyField = value;
        this.RaisePropertyChanged("TimeProperty");
    }
}

当我创建一个数据类型为-
类型的属性时,我遇到了相同的错误。在这方面,我得到了一个错误-有一个错误反映类型。我一直在检查调试驳接中每个异常的“InnerException”,并在我的示例中获得了特定的字段名(即
类型
)。解决办法如下:

    [XmlIgnore]
    public Type Type { get; set; }

有时,这种类型的错误是因为您没有无参数类的构造函数

谢谢您的提醒!我讨厌这是一个运行时错误与小前
[XmlIgnore]
string [] strFielsName {get;set;}
[System.Xml.Serialization.XmlElementAttribute(DataType="time", Order=3)]
public string TimeProperty {
    get {
        return this.timePropertyField;
    }
    set {
        this.timePropertyField = value;
        this.RaisePropertyChanged("TimeProperty");
    }
}
[System.Xml.Serialization.XmlElementAttribute(Order=3)]
public string TimeProperty {
    get {
        return this.timePropertyField;
    }
    set {
        this.timePropertyField = value;
        this.RaisePropertyChanged("TimeProperty");
    }
}
    [XmlIgnore]
    public Type Type { get; set; }