【问题标题】:NullReferenceException when validating xml with .NET 4.6使用 .NET 4.6 验证 xml 时出现 NullReferenceException
【发布时间】:2015-09-26 00:36:29
【问题描述】:

我正在测试从 .NET 版本 4.5.1 切换到 4.6,并在对可选属性使用唯一约束时在 xsd 验证中遇到 NullReferenceException。

at System.Xml.Schema.KeySequence.ToString()
at System.Xml.Schema.XmlSchemaValidator.EndElementIdentityConstraints(Object typedValue, String stringValue, XmlSchemaDatatype datatype)
at System.Xml.Schema.XmlSchemaValidator.InternalValidateEndElement(XmlSchemaInfo schemaInfo, Object typedValue)
at System.Xml.XsdValidatingReader.ProcessEndElementEvent()
at System.Xml.XsdValidatingReader.ProcessElementEvent()
at System.Xml.XsdValidatingReader.ProcessReaderEvent()
at System.Xml.XsdValidatingReader.Read()
at ConsoleApplication.Program.Main(String[] args)

这是在针对 v4.5.x 时运行但在使用 4.6 时失败并出现 NullReferenceException 的剥离代码。 (在 VS2013 和 VS2015 的 Win7 上测试)。这在xml中合法吗?即使不是,它也应该引发一些 XmlException。

架构:

<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
  <xs:element name="Enumerations">
    <xs:complexType>
      <xs:sequence>
        <xs:element name="Enum" minOccurs="0" maxOccurs="unbounded">
          <xs:complexType>
            <xs:attribute name="id" type="xs:string" use="optional"/>
          </xs:complexType>
        </xs:element>
      </xs:sequence>
    </xs:complexType>
    <xs:unique name="unique_EnumId_contraint">
      <xs:selector xpath="Enum"/>
      <xs:field xpath="@id"/>
    </xs:unique>
  </xs:element>
</xs:schema>

XML:

<?xml version="1.0" encoding="utf-8"?>
<Enumerations>
  <Enum />
  <Enum />
</Enumerations>

C#代码:

var settings = new XmlReaderSettings();
settings.ValidationType = ValidationType.Schema;
settings.Schemas.Add(null, "enumerations.xsd");

using (var xmlReader = XmlReader.Create("enumerations.xml", settings))
{
    while (xmlReader.Read())
    {
        if (xmlReader.NodeType == XmlNodeType.Element)
        {
            Console.CursorLeft = xmlReader.Depth * 4;
            Console.WriteLine(xmlReader.Name);
        }
    }
}

【问题讨论】:

  • 看起来 Enum 节点没有 id
  • 这是为了保持与以前格式的向后兼容性。我可以检查代码的唯一性,但它应该像在 4.5.x 中一样工作

标签: c# .net xsd


【解决方案1】:

我可以重现这个。对我来说看起来像是一个错误(&lt;rant&gt;.NET 4.6 有很多...&lt;/rant&gt;)。你应该报告给Microsoft Connect

虽然此问题已修复,但您可以在此处查看来源:http://referencesource.microsoft.com/#System.Xml/System/Xml/Schema/ConstraintStruct.cs,091791a9542f1952

它告诉我们可以使用AppContext 开关来克服它,因此只需在任何其他代码之前添加此代码即可:

AppContext.SetSwitch("Switch.System.Xml.IgnoreEmptyKeySequences", true);

有关此开关的更多信息,请访问此处:Mitigation: XML Schema Validation - 请注意这句话:“此更改的影响应该是最小的”:-)

PS:我相信您也可以使用适当的 .config 文件更改这些开关。

【讨论】:

  • 谢谢。我不知道 MS 仍在更改 XML 解析。针对另一个框架版本的另一个问题。在我的情况下,相同的代码是否仅使用此开关的另一个默认值运行,还是执行旧代码?
  • 不,它仍然是 .NET 4.6,但它需要另一条路径(可能是旧代码路径,也可能不是)。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-01-15
  • 1970-01-01
  • 2012-06-25
  • 2014-02-01
  • 1970-01-01
相关资源
最近更新 更多