zoukankan      html  css  js  c++  java
  • xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance(xsi:schemaLocation详解)

    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"中xsi的意思是 :
    本xml文件中要用到某些来自xsi代表的“http://www.w3.org/2001/XMLSchema-instance”这个命名空间的元素  
    比如用来引入无命名空间schema文件的noNamespaceSchemaLocation="XXX";
    以及引入自带命名空间的schema文件的schemaLocation="XXX"这些元素。
    这些元素是包含在xsi命名空间中的,所有的xml文件只要引用这些元素 就要引入xsi这个命名空间。   
    xsi这三个字母不是硬性规定,只是大家都这么用,方便阅读而已。

    xsi是http://www.w3.org/2001/XMLSchema-instance的别名。
    这样用于下面元素的时候可以这样<xsi:element />而不用带上长长的uri。
    有了命名空间以后,在同一级元素就可以使用同一个元素名称而不会混乱:
    <xsi1:element />
    <xsi2:element />

    在实例中引用模式文档

    XML Schema提供了两个在实例文档中使用的特殊属性,用于指出模式文档的位置。这两个属性是:xsi:schemaLocation和xsi:noNamespaceSchemaLocation,前者用于声明了目标名称空间的模式文档,后者用于没有目标名称空间的模式文档,它们通常在实例文档中使用。

    4.5.7.1  xsi:schemaLocation属性

    xsi:schemaLocation属性的值由一个URI引用对组成,两个URI之间以空白符分隔。第一个URI是名称空间的名字,第二个URI给出模式文档的位置,模式处理器将从这个位置读取模式文档,该模式文档的目标名称空间必须与第一个URI相匹配。我们看例4-28。

    例4-28  book6.xml

    <?xml version="1.0" encoding="GB2312"?>
    <book xmlns="http://www.sunxin.org/book"   ①
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  ②
    xsi:schemaLocation="http://www.sunxin.org/book http://www.sunxin.org/ 
    book.xsd">  ③
    <title>《Struts 2深入详解》</title>
    <author>孙鑫</author>
    </book>

    ① 声明默认的名称空间(http://www.sunxin.org/book)。

    ② 声明XML Schema实例名称空间(http://www.w3.org/2001/XMLSchema-instance),并将xsi前缀与该名称空间绑定,这样模式处理器就可以识别xsi:schemaLocation属性。XML Schema实例名称空间的前缀通常使用xsi。

    ③ 使用xsi:schemaLocation属性指定名称空间http://www.sunxin.org/book和模式位置http://www.sunxin.org/book.xsd相关。要注意,在这个例子中,book.xsd中声明的目标名称空间要求是http://www.sunxin.org/book

    一个可能的模式文档book.xsd如例4-29所示。

    例4-29  book.xsd

    <?xml version="1.0" encoding="UTF-8"?>
    <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" 
    xmlns="http://www.sunxin.org/book" 
    targetNamespace="http://www.sunxin.org/book" 
    elementFormDefault="qualified">
    
    <xs:element name="book" type="bookType"/>
    <xs:complexType name="bookType">
    <xs:sequence>
    <xs:element name="title" type="xs:string"/>
    <xs:element name="author" type="xs:string"/>
    </xs:sequence>  
    </xs:complexType>
    </xs:schema>

    实际上,xsi:schemaLocation属性的值也可以由多个URI引用对组成,每个URI引用对之间使用空白符分隔。例4-30的实例文档使用了多个名称空间,xsi:schemaLocation属性的值包含了两对URI。

    例4-30  books.xml

    <?xml version="1.0" encoding="GB2312"?>
    <books xmlns="http://www.sunxin.org/bks" xmlns:p="http://www.sunxin.org/people"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.sunxin.org/bks bks.xsd
    http://www.sunxin.org/people people.xsd">
    <book>
    <title>JSP深入编程</title>
    <author>
    <p:name>张三</p:name>
    <p:title>作家</p:title>
    </author>
    </book>
    <book>
    <title>XML从入门到精通</title>
    <author>
    <p:name>李四</p:name>
    <p:title>教师</p:title>
    </author>
    </book>
    </books>

    XML Schema推荐标准中指出,xsi:schemaLocation属性可以在实例中的任何元素上使用,而不一定是根元素,不过,xsi:schemaLocation属性必须出现在它要验证的任何元素和属性之前。

    此外,要注意的是,XML Schema推荐标准并没有要求模式处理器必须要使用xsi:schemaLocation属性,某些模式处理器可以通过其他的方式来得到模式文档的位置,而忽略xsi:schemaLocation属性。

    xsi:noNamespaceSchemaLocation属性

    xsi:noNamespaceSchemaLocation属性用于引用没有目标名称空间的模式文档。与xsi:schemaLocation属性不同的是,xsi:noNamespaceSchemaLocation属性的值是单一的值,只是用于指定模式文档的位置。例4-31显示了在实例文档中xsi:noNamespaceSchema Location属性的使用。

    例4-31  book7.xml

    <?xml version="1.0" encoding="GB2312"?>
    <book xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:noNamespaceSchemaLocation="book.xsd" 
    isbn="978-7-121-06812-6" >
    <title>《Struts 2深入详解》</title>
    <author>孙鑫</author>
    </book>

    与xsi:schemaLocation属性一样,xsi:noNamespaceSchemaLocation属性也可以在实例中的任何元素上使用,而不一定是根元素,不过,xsi:noNamespaceSchemaLocation属性必须出现在它要验证的任何元素和属性之前。

    此外,要注意的是,XML Schema推荐标准并没有要求模式处理器必须要使用xsi:noNamespaceSchemaLocation属性,某些模式处理器可以通过其他的方式来得到模式文档的位置,而忽略xsi:noNamespaceSchemaLocation属性。

    =============

    http://xj84.iteye.com/blog/1135958

    xmlns 说明参见
    http://www.cnblogs.com/jhxk/articles/1619105.html

    xsi:schemaLocation说明参见http://www.w3school.com.cn/schema/schema_example.asp

    xsi:schemaLocation中的模式文档.xsd文件一般都在本地,比如spring

    <beans default-autowire="byName"

    xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

    xmlns:aop="http://www.springframework.org/schema/aop" xmlns:util="http://www.springframework.org/schema/util"

    xsi:schemaLocation="http://www.springframework.org/schema/beans 

    http://www.springframework.org/schema/beans/spring-beans-2.0.xsd 

    http://www.springframework.org/schema/aop 

    http://www.springframework.org/schema/aop/spring-aop-2.0.xsd 

    http://www.springframework.org/schema/util 

    http://www.springframework.org/schema/util/spring-util-2.5.xsd ">

    中的.xsd文件都在spring包内,如下图:


     spring.schemas中定义了文档的具体地址:

     

    =============================

    http://www.programfan.com/club/showpost.asp?id=24294

    schemaLocation 属性是在 XML 架构实例命名空间 http://www.w3.org/2001/XMLSchema-instance(通常与前缀 xsi 关联)中定义的,它仅适用于 XML 实例文档,而不适用于 XML 架构文档。它区别于在 XML 架构命名空间 http://www.w3.org/2001/XMLSchema 中定义的 schemaLocation 属性。 

    xsi:schemaLocation 属性提供一种方法来查找在 XML 实例文档中定义的命名空间的 XML 架构定义。它的值是用空白分隔的统一资源标识符 (URI) 对的列表,其中的每一对 URI 都依次包含一个命名空间以及该命名空间的 XML 架构定义(通常为 .xsd 文件)的位置。 

    当将 XML 文档反序列化为对象时,XmlSerializer 类忽略 xsi:schemaLocation 属性。但是,在验证 XML 文档时,XmlValidatingReader 类可以使用该属性值来获取 XML 架构定义。

    //JDom里面Namespace是单体模式,报“xsi命名空间已定义”的错误就是因为程序里实例化了两个URL都为xsi而Value不同的Namespace实例

  • 相关阅读:
    Windows | Linux/Ubuntu 16.04 安装编辑器 Sublime Text 3
    Linux/Ubuntu 16.04 好用的视频播放器 SMPlayer
    Webpack实战(二):webpack-dev-server的介绍与用法
    Webpack实战(一):Webpack打包工具安装及参数配置
    第一天开通博客
    Spring Cloud Eureka 服务注册与发现中心
    使用 Docker Compose 部署 Nginx 配置虚拟主机
    Spring Boot 中 Redis 的使用
    Linux 安装 Docker Compose 及常用命令汇总
    Spring Boot 集成 Swagger2 构建 RESTful API 文档
  • 原文地址:https://www.cnblogs.com/zhangchengye/p/6293684.html
Copyright © 2011-2022 走看看