我今天开始在 WCF 反序列化中遇到错误 - 代码一直没有改变并且工作了几个月。
问题是我正在获取运行时 XmlException
说“名称不能以‘<’字符开头”。我已调试到 .NET 源代码,似乎错误出在反序列化我们的 WCF 服务调用的返回对象中。这些对象是使用自动属性定义的,似乎支持字段的名称类似于 <MyProperty>k_BackingField
,这是 XmlException 的来源。
我在网上看到了其他一些引用资料,其中人们接受的解决方案是“我更改了我的代码以不使用自动属性”,这对我来说是不能接受的,因为我需要更改 100 个对象, (其中有 1000 个属性)。此外,当我上周运行这段相同的代码时,它运行良好,似乎并没有影响所有序列化的 DTO,只有一些。
更令人沮丧的是,它似乎有点断断续续。今天早上偶尔会抛出异常...!
问题;
- 为什么在未更改的代码和未更改的框架源中突然出现此问题?
- 如何在不修改所有 DTO 以使用完全实现的属性的情况下解决此问题?
更新:经过一天左右的正常工作后,这个问题再次出现 - 没有理由我找不到它为什么会工作/不工作/再次工作的原因,但我们就是这样。
我已使用 ServiceKnownType
进一步追踪问题与我在 ServiceContracts 上的一些代码有关属性,用于定义序列化的已知类型。似乎虽然报告有错误的类型甚至不是我当时进行的服务调用的一部分,但此错误发生在属于此已知类型“发布”行为的一部分的类型上。
当我使用一些代理创建代码来应用一些服务行为时出现问题;
IOperationBehavior innerBehavior = new PreserveReferencesOperationBehavior(
description, this.preserveReferences, this.maxItemsInObjectGraph);
innerBehavior.ApplyClientBehavior(description, proxy);
我无法调试 ApplyClientBehavior
代码,因为它是 System.ServiceModel
的一部分(或者我可以吗?),但该方法中的某些内容正在尝试验证我使用 ServiceKnownType
发布的所有类型属性,并用这个 XmlException
打破其中的一些.我不知道为什么某些类型会失败 - 并且仅针对它们的某些属性。
这是收到错误报告的类型的示例;
[Serializable]
public class MyDataObject
{
public ActivitySession(string id)
{
this.Id = id;
this.IsOpen = true;
}
public string Id { get; set; }
public bool IsValid { get; set; }
}
异常报告错误 Id
-> <Id>k_BackingField cannot start with '<'
所以在那个类中没有什么争议,也不需要考虑继承。它甚至不是服务契约(Contract)的一部分,只是它之前作为已知的序列化类型发布。
这现在变得非常深奥,所以我不期待答案,而只是更新问题所在。
最佳答案
我想我已经找到了更多信息来帮助解释这个问题(至少在为什么错误只出现在某些类型上)。
收到异常报告的 DTO 是;
- 作为我的
[ServiceKnownType]
属性的一部分发布 - 标有
[Serializable]
- NOT 标有
[DataContract]
将 [DataContract]
属性添加到类型可以解决此问题。我不知道为什么,也仍然不知道为什么这个错误在发生时是间歇性的,但在它影响的什么上是一致的。
关于c# - WCF 反序列化中的 XmlException : "Name cannot begin with ' <'" - in automatic property backing fields,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13906527/