使用XSD进行批量数据导入时生成的XML数据有效性这样的功能已经不是第一次做了,之前做的时候都没有碰到什么问题,这些天在开发中遇到了一个很头痛的问题就是无论XSD文件规则怎么写,验证都是通过的。

下面是具体的代码:

C#验证部分:

        /// <summary>
        /// 对已转换成映射XML文件使用指定架构文件进行验证
        /// </summary>
        /// <param name="mappingXmlFile">映射XML文件</param>
        /// <param name="schemaFile">架构文件</param>
        /// <returns>返回空字符串表示验证成功,否则返回错误信息</returns>
        public string ValidateMappingXMLFile(string mappingXmlFile, string schemaFile)
        {
            string namespaceUrl = "http://tempuri.org/MsisdnSchema.xsd";
            XmlReaderSettings settings = new XmlReaderSettings();
            settings.ValidationType = ValidationType.Schema;
            settings.Schemas.Add(namespaceUrl, schemaFile);
            settings.ValidationEventHandler += new System.Xml.Schema.ValidationEventHandler(settings_ValidationEventHandler);

            sb = new StringBuilder();

            XmlReader reader = XmlReader.Create(mappingXmlFile, settings);
            try
            {
                reader.MoveToContent();
                while (reader.Read())
                {
                    if (reader.NodeType == XmlNodeType.Document && reader.NamespaceURI != namespaceUrl)
                    {
                        return "Data does not match the specifications!";
                    }
                }
            }
            catch (XmlException ex)
            {
                sb.AppendFormat(ex.Message + "\n");
            }
            finally
            {
                reader.Close();
            }
            if (String.IsNullOrEmpty(sb.ToString()))
            {
                return string.Empty;
            }
            else
            {
                return "Validation Faild,Please check the validity of the data:" + sb.ToString();
            }
        }

        public void settings_ValidationEventHandler(object sender, System.Xml.Schema.ValidationEventArgs e)
        {
            sb.Append(e.Message + "\n");
        }

XML数据:

 <?xml version="1.0" encoding="utf-8"?>
 <MSISDN>
  <List>
     <BATCH_IMPORT_ID>6adbca51-c55f-4022-bcc0-84b209a78a38</BATCH_IMPORT_ID>
     <BATCH_NO>20131027172271517</BATCH_NO>
     <PORT_IN_MSISDN>31632000000</PORT_IN_MSISDN>
     <CUSTOMER_TYPE>Business</CUSTOMER_TYPE>
     <ID_TYPE>Passport</ID_TYPE>
     <ID_NUMBER>1234567</ID_NUMBER>
     <NATIONALITY>Netherlands</NATIONALITY>
     <DAY_OF_BIRTH>2013-10-27</DAY_OF_BIRTH>
     <COUNTRY_ID>Netherlands</COUNTRY_ID>
     <LANGUAGE>Dutch - The Netherlands</LANGUAGE>
     <COMPANY>ET.</COMPANY>
     <STATUS_ID>Active</STATUS_ID>
     <TITLE_ID>Mr.</TITLE_ID>
     <FIRST_NAME>Mark</FIRST_NAME>
     <MIDDLE_NAME>
     </MIDDLE_NAME>
     <LAST_NAME>Mulder</LAST_NAME>
     <EMAIL>654645</EMAIL>
     <ADDRESS>Schipholboulevard</ADDRESS>
     <HOUSE_NO>249</HOUSE_NO>
     <HOUSE_EXTENTION>
     </HOUSE_EXTENTION>
     <ZIP_CODE>4324</ZIP_CODE>
     <CITY>Schipholboulevard</CITY>
     <PACKAGE_NAME>88 mobile prepaid 2.5.0</PACKAGE_NAME>
     <BILLING_EMAIL>martin.mulder@elephanttalk.com</BILLING_EMAIL>
     <CUSTOMER_ID_DONOR>56346546</CUSTOMER_ID_DONOR>
     <WISHDATE_PORTING>2013-10-27</WISHDATE_PORTING>
     <NETWORK_OPERATOR>BEN</NETWORK_OPERATOR>
     <SERVICE_PROVIDER>Atlantic Telecom</SERVICE_PROVIDER>
   </List>
 </MSISDN>

XSD验证架构

 <?xml version="1.0" encoding="utf-8"?>
 <xs:schema
           id="MSISDNSchema"
           targetNamespace="http://tempuri.org/MsisdnSchema.xsd"
           elementFormDefault="qualified"
           attributeFormDefault="unqualified"
           xmlns="http://tempuri.org/MsisdnSchema.xsd"
           xmlns:mstns="http://tempuri.org/MsisdnSchema.xsd"
           xmlns:xs="http://www.w3.org/2001/XMLSchema">
   <xs:element name="MSISDN">
     <xs:complexType>
       <xs:sequence>
         <xs:element maxOccurs="unbounded" name="List">
           <xs:complexType>
             <xs:sequence>
               <xs:element name="BATCH_IMPORT_ID" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="36"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="BATCH_NO" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="PORT_IN_MSISDN">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="CUSTOMER_TYPE" minOccurs="0" default="Business">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="ID_TYPE" minOccurs="0" default="Passport">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="ID_NUMBER" default="1234567">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="20"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="NATIONALITY" minOccurs="0" default="Netherlands">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="20"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="DAY_OF_BIRTH" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:date">
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="COUNTRY_ID" minOccurs="0" default="Netherlands">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="LANGUAGE" minOccurs="0" default="Netherlands">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="COMPANY" minOccurs="0" fixed="ET.">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="STATUS_ID" minOccurs="0" fixed="Active">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="20"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="TITLE_ID" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="20"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="FIRST_NAME" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="MIDDLE_NAME" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="LAST_NAME" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="EMAIL" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                     <xs:pattern value="([a-zA-Z0-9_\-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([a-zA-Z0-9\-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="ADDRESS" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="HOUSE_NO" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="25"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="HOUSE_EXTENTION" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="ZIP_CODE" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="25"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="CITY" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="PACKAGE_NAME" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="BILLING_EMAIL" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="CUSTOMER_ID_DONOR" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="100"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="WISHDATE_PORTING" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:date">
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="NETWORK_OPERATOR" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="10"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
               <xs:element name="SERVICE_PROVIDER" minOccurs="0">
                 <xs:simpleType>
                   <xs:restriction base="xs:string">
                     <xs:maxLength value="50"/>
                   </xs:restriction>
                 </xs:simpleType>
               </xs:element>
             </xs:sequence>
           </xs:complexType>
         </xs:element>
       </xs:sequence>
     </xs:complexType>
   </xs:element>
 </xs:schema>

可见,<EMAIL>654645</EMAIL>项是一个不符合Email正则表达式验证的Email地址,可是执行的结果依然是没有进行验证。

在园子里的另一篇文章http://q.cnblogs.com/q/38157/ 给了我启发,我把XML数据的对XSD命名空间的引用,<MSISDN xmlns="http://tempuri.org/MsisdnSchema.xsd" >

发现这次验证是可以正常进行的,说明问题出在了XML数据上。

“XmlReader 在执行验证的时候不光需要xsd文件,还需要xml文件显示的引用xsd的NameSpaces,这样才就可以去匹配验证每个元素。”果然如帖子中说的一样。

可这样格式的XML数据,在进行校验过后,要转换成Dataset进行再次处理会比较麻烦,需要先获取XML架构再取数据,那么能不能不修改XML数据就验证成功呢?

我对代码和XSD数据进行了如下修改:

xsd里面
去掉

targetNamespace="http://tempuri.org/MsisdnSchema.xsd"

代码里面(写出的部分为替换注释掉部分的代码)

//string namespaceUrl = "http://tempuri.org/MsisdnSchema.xsd";

//settings.Schemas.Add(namespaceUrl, schemaFile);

settings.Schemas.Add(null, schemaFile);

//if (reader.NodeType == XmlNodeType.Document && reader.NamespaceURI != namespaceUrl)

if (reader.NodeType == XmlNodeType.Document && reader.NamespaceURI !=null)

再运行程序,代码就通过了,验证可以正常运行。

可能有不少同学在学习XSD验证XML的时候,会参考园子里的一篇博客

http://www.cnblogs.com/chenxizhang/archive/2009/06/19/1507121.html

我想指出的是,

如果XML数据文件没有引用任何XSD的命名空间,那么在代码中,是不需要设置XmlReader的namespaceUrl的,并且XSD中也不需要设置targetNamespace项的值,否则验证是不会进行的,验证结果永远都是成功。

C# xsd 验证 XML数据有效性 问题的更多相关文章

  1. 使用架构(XSD)验证XML文件

    假使说XML是一个数据库,那么XSD就是这个数据库的结构.由此可见,XSD是如此重要,如果没有它,我们如何声明以及验证我们需要的XML数据文件的格式和合法性呢?那是不可能完成的任务,如果你将XML数据 ...

  2. C# 利用Xsd验证xml

    最近做项目时,用到了xml的序列化与反序列化, 发现最好用xsd来验证xml, 因为反序列化xml不校验xsd. 方法:xmlData变量为xml字符串 MemoryStream ms = new M ...

  3. 用xsd验证xml

    using System; using System.Text; using System.Xml; namespace WebApplication1 { public partial class ...

  4. XSD(XML Schema Definition)用法实例介绍以及C#使用xsd文件验证XML格式

    XML Schema 语言也称作 XML Schema 定义(XML Schema Definition,XSD),作用是定义 XML 文档的合法构建模块,类似 DTD,但更加强大. 作用有: ①定义 ...

  5. C# 使用xsd文件验证XML 格式是否正确

    C# 使用xsd文件验证XML 格式是否正确 核心示例代码: //创建xmlDocument XmlDocument doc = new XmlDocument(); //创建声明段 如<?xm ...

  6. 28.XSD(XML Schema Definition)用法实例介绍以及C#使用xsd文件验证XML格式

    转自https://www.cnblogs.com/gdjlc/archive/2013/09/08/3308229.html XML Schema 语言也称作 XML Schema 定义(XML S ...

  7. XML的应用 ---- 从一个范例看xml数据、xsd验证、xslt样式

    从一个范例看XML的应用 引言 如果你已经看了Asp.Net Ajax的两种基本开发模式 这篇文章,你可能很快会发现这样一个问题:在那篇文章的方式2中,客户端仅仅是发送了页面上一个文本框的内容到服务端 ...

  8. Delphi 7验证XML合法性(利用DTD、XSD)

    拥有正确语法的XML被称为“形式良好”的XML.通过DTD验证的XML是“合法”的XML.DTD(文档类型定义)的作用是定义XML 文档的合法构建模块.它使用一系列的合法元素来定义文档结构.XML S ...

  9. 通过xsd schema结构来验证xml是否合法

    import sys import StringIO import lxml from lxml import etree from StringIO import StringIO # Constr ...

随机推荐

  1. DotNetBar For Windows Forms 12.5.0.2 官方原版及注册

    转自原文DotNetBar For Windows Forms 12.5.0.2 官方原版及注册 DotNetBar是一款带有56个 Windows Form 控件的工具箱,使开发人员可以轻而易举地创 ...

  2. C#获取外网IP、本机MAC地址及Ping的实现

    原文 获取外网IP, C#获取本机的MAC地址,C#通过编程方式实现Ping 获取外网IP地址 思路是通过WebRequest连接一些网上提供IP查询服务的网站,下载到含有你的IP的网页,然后用正则表 ...

  3. [转] C#调用外部DLL

    原文地址 每种编程语言调用DLL的方法都不尽相同,在此只对用C#调用DLL的方法进行介绍.首先,您需要了解什么是托管,什么是非托管.一般可以认为:非托管代码主要是基于win 32平台开发的DLL,ac ...

  4. mysql彻底删除

    yum remove mysql mysql-server mysql-libs compat-mysql51rm -rf /var/lib/mysqlrm /etc/my.cnf查看是否还有mysq ...

  5. ffmpeg源码分析二:main函数和transcode函数 (转2)

    原帖地址:http://blog.csdn.net/austinblog/article/details/24804455 首先从main函数看起,关键解释部分已加注释,该函数在ffmpeg.c文件中 ...

  6. 修改SecureCRT终端的Home和End功能键。

    SecureCRT真是个不错的ssh客户端工具,但在使用时发现跟自己的一些使用习惯不符合,例如home.end.pageup.pagedown和delete等键. 默认情况下一些按键的功能如下: pa ...

  7. Spring 学习记录8 初识XmlWebApplicationContext(2)

    主题 接上文Spring 学习记录7 初识XmlWebApplicationContext refresh方法 refresh方法是定义在父类AbstractApplicationContext中的. ...

  8. 操作SQL Server的帮助类

    可作为以后开发的参考代码,也可以再整理下,代码如下: using System; using System.Collections.Generic; using System.Linq; using ...

  9. 浅谈JobExecutionContext&JobDataMap

  10. php-yii-form标签

    yii 标签用法(模板) (2013-08-14 17:28:19) 转载▼ 标签: it 分类: yii yii模板中的label标签 <?php echo $form->labelEx ...