要深入了解Spring机制,首先需要知道Spring是怎样在IoC容器中装配Bean的。而了解这一点的前提是,要搞清楚Spring基于Schema的Xml配置方案。

在深入了解之前,必须要先明白几个标签的意思(我会逐步引导读者理解,刚开始的懵懂无所谓,读者自会渐入佳境。初极狭,才通人。复行数十步,豁然开朗。)。

  1. 什么是XML Schema?

  用来描述 XML文档的结构,也被简称为XSD(XML Schema Definition),是一些规则的集合。(方式:通过定义schema文件 如 spring-tx-3.0.xsd)

  2. xmlns?

  命名空间是W3C推荐标准提供的一种统一命名XML文档中的元素和属性的机制。

  3.xsd文件?

  使用XML w3c 标准命名空间中规定的元素和属性编写的以targetNamespace作为{目标命名空间}的XML文件,能够约束引入此{目标命名空间}定义的元素和属性的XML文件。

  4.targetNamespace?

  目标命名空间,它的主要作用是指明Schema定义的元素的命名空间。

亲,是不是蒙圈了?我举个栗子你感受一下,下面是一个note.xsd文件示例:

代码001 

1 <?xml version="1.0"?>
<xs:schema
xmlns:xs="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.w3school.com.cn">
<xs:element name="note">
<xs:complexType>
<xs:sequence>
<xs:element name="to" type="xs:string"/>
<xs:element name="from" type="xs:string"/>
<xs:element name="heading" type="xs:string"/>
<xs:element name="body" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>

这个xsd文件你就认为它是个有约束力的文件,它将约束后面定义的与bean相关的xml,

第3行的xmlns就是一个统一的规则,它就是"法",平民百姓可以自由支配自己,但必须遵循这个"法"的管制。

5-14行就是约束的方法,第五行"<"后面的"xs"是这个约束的小名,对应着第3行"xmlns"后面的"xs",而约束文件的全名就是第三行后面的以http开始的链接。(这个全名其实可以随意定义,但是一般情况下用网站目录来命名,一是便于区分,二是体现出本文件在服务器中的组织架构关系)。

第4行是本约束规则要约束哪个文件?targetNamespace后面就是被约束文件的大名。通缉令上写上大名:抓捕汉奸王二麻子,然后捕头就按图索骥,寻找王二麻子这个人。下面是王二麻子:

代码002

1 <?xml version="1.0"?>
<note xmlns="http://www.w3school.com.cn"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.w3school.com.cn
             http://www.w3school.com.cn /note.xsd">
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don't forget the meeting!</body>
</note>

看到木有,第2行xmlns后面,行不改名,坐不改姓,http://www.w3school.com.cn这就是这个配置文件内定义的大名(代号王二麻子)。5到8行是这个bean配置文件的属性,这些属性遵循的规则就是前面讲到的代码001的5-14行约束。

这一行的xmlns后面本来也有个冒号+小名的,不写表示默认命名空间,spring中bean的定义都使用默认命名空间。

那么这个xmlns:xsi又是什么呢?兄弟你记住一点,xmlns就是"法",它后面的东西都是定义的规则的大名和小名。

你看,代码001中第三行说明,规则的小名叫xs,规则的大名叫http://www.w3.org/2001/XMLSchema。

那么,代码002中,xsi就是规则小名,后面的http://www.w3.org/2001/XMLSchema-instance就是规则的大名了。(跟代码001不同的是,001是自定义的,而xsi是spring原配的。)

第4行是调用xsi规则的schemaLocation子规则,这个规则是寻找具体约束它的文件。(通过后面的链接就可以找到代码001这个文件。)

与xmlns:xsi类似,spring内置了很多Schema约束文件,如:beans、aop、tx、mvc、util等等,不一而足。

有了上面的栗子,spring项目里具体的xml文件就有所了解了,再来看,下面是一个小栗子的配置文件:

代码003

1 <?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd"> <!-- 扫描类包,将标注Spring注解的类自动转化Bean,同时完成Bean的注入 -->
<context:component-scan base-package="com.baobaotao.dao"/>
<context:component-scan base-package="com.baobaotao.service"/> <!-- 配置数据源 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close"
p:driverClassName="com.mysql.jdbc.Driver"
p:url="jdbc:mysql://localhost:3306/sampledb"
p:username="root"
p:password="2009118293zjl" /> <!-- 配置Jdbc模板 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"
p:dataSource-ref="dataSource" /> <!-- 配置事务管理器 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
p:dataSource-ref="dataSource" /> <!-- 通过AOP配置提供事务增强,让service包下所有Bean的所有方法拥有事务 -->
<aop:config proxy-target-class="true">
<aop:pointcut id="serviceMethod"
expression=" execution(* com.baobaotao.service..*(..))" />
<aop:advisor pointcut-ref="serviceMethod" advice-ref="txAdvice" />
</aop:config>
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" />
</tx:attributes>
</tx:advice>
</beans>

代码003中,3-7行都是spring的内置xsd,8-15行是调用xsi的schemaLocation去寻找具体的xsd位置。18-48行都是为各个规则定义了一些约束对象,王二麻子一箩筐。

如果你的电脑连了网,在myeclipse中打开这个xml的时候,你可以随便挑一个规则,鼠标指在后面的链接上,按住ctrl键,点击链接,比如点击http://www.springframework.org/schema/tx/spring-tx-3.0.xsd这个链接,它会直接从内置浏览器通过访问链接打开这个xsd文件,下面是打开后的部分代码:

 <?xml version="1.0" encoding="UTF-8" standalone="no" ?>
- <xsd:schema xmlns="http://www.springframework.org/schema/tx" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:beans="http://www.springframework.org/schema/beans" xmlns:tool="http://www.springframework.org/schema/tool" targetNamespace="http://www.springframework.org/schema/tx" elementFormDefault="qualified" attributeFormDefault="unqualified">
<xsd:import namespace="http://www.springframework.org/schema/beans" schemaLocation="http://www.springframework.org/schema/beans/spring-beans-3.0.xsd" />
<xsd:import namespace="http://www.springframework.org/schema/tool" schemaLocation="http://www.springframework.org/schema/tool/spring-tool-3.0.xsd" />
- <xsd:annotation>
- <xsd:documentation>
- <![CDATA[
Defines the elements used in the Spring Framework's declarative
transaction management infrastructure. ]]>
</xsd:documentation>
</xsd:annotation>
- <xsd:element name="advice">

这个就是tx约束文件,读者可以大概看一下前面几行的意思,这里不做详解。

但是有个问题,一般情况下开发项目怎么可能保证联网呢?不联网的情况下这些约束如何生效?

其实,spring的jar包中都放了这些xsd文件。比如用压缩工具打开org.springframework.beans-3.0.5.RELEASE.jar这个jar包,

这里面都有。

Spring除了基于XML的配置,还有基于Bean,基于注解的配置。但是基于XML的配置功能最强,是基础,是必须首先要了解的。

天道酬勤。共勉。

  

  

(spring-第2回【IoC基础篇】)Spring的Schema,基于XML的配置的更多相关文章

  1. Spring+SpringMVC+MyBatis+easyUI整合基础篇(六)maven整合SSM

    写在前面的话   承接前文<Spring+SpringMVC+MyBatis+easyUI整合基础篇(五)讲一下maven>,本篇所讲述的是如何使用maven与原ssm项目整合,使得一个普 ...

  2. Spring+SpringMVC+MyBatis+easyUI整合基础篇(八)mysql中文查询bug修复

    写在前面的话 在测试搜索时出现的问题,mysql通过中文查询条件搜索不出数据,但是英文和数字可以搜索到记录,中文无返回记录.本文就是写一下发现问题的过程及解决方法.此bug在第一个项目中点这里还存在, ...

  3. Spring+SpringMVC+MyBatis+easyUI整合基础篇(十一)SVN服务器进阶

    日常啰嗦 上一篇文章<Spring+SpringMVC+MyBatis+easyUI整合基础篇(十)SVN搭建>简单的讲了一下SVN服务器的搭建,并没有详细的介绍配置文件及一些复杂的功能, ...

  4. Spring+SpringMVC+MyBatis+easyUI整合基础篇(十二)阶段总结

    不知不觉,已经到了基础篇的收尾阶段了,看着前面的十几篇文章,真的有点不敢相信,自己竟然真的坚持了下来,虽然过程中也有过懒散和焦虑,不过结果还是自己所希望的,克服了很多的问题,将自己的作品展现出来,也发 ...

  5. Spring+SpringMVC+MyBatis+easyUI整合基础篇

    基础篇 Spring+SpringMVC+MyBatis+easyUI整合基础篇(一)项目简介 Spring+SpringMVC+MyBatis+easyUI整合基础篇(二)牛刀小试 Spring+S ...

  6. Spring基础篇——通过Java注解和XML配置装配bean

    自动化装配的确有很大的便利性,但是却并不能适用在所有的应用场景,比如需要装配的组件类不是由自己的应用程序维护,而是引用了第三方的类库,这个时候自动装配便无法实现,Spring对此也提供了相应的解决方案 ...

  7. Spring基础篇——通过Java注解和XML配置装配bean(转载)

      作者:陈本布衣 出处:http://www.cnblogs.com/chenbenbuyi 本文版权归作者和博客园共有,欢迎转载分享,但必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留 ...

  8. Spring cloud系列教程第十篇- Spring cloud整合Eureka总结篇

    Spring cloud系列教程第十篇- Spring cloud整合Eureka总结篇 本文主要内容: 1:spring cloud整合Eureka总结 本文是由凯哥(凯哥Java:kagejava ...

  9. Spring框架入门之基于xml文件配置bean详解

    关于Spring中基于xml文件配置bean的详细总结(spring 4.1.0) 一.Spring中的依赖注入方式介绍 依赖注入有三种方式 属性注入 构造方法注入 工厂方法注入(很少使用,不推荐,本 ...

随机推荐

  1. node环境下处理get post

    前言:今天刚学get,post.这里只是几下今天的理解.so文章只供新手参考. 编译器是webstorm 搭建后服务器后(具体请查看上篇文章) 在routes文件夹下的index.js文件中写入 如图 ...

  2. IIS 安装 pydio

    Introduction In this how-to, we’ll see the installation of Pydio (Put Your Data In Orbit), which is ...

  3. 一些用于数据整理的excel函数

    我们经常要从外部数据源(如数据库.文本文件或网页等)将数据导入excel中,但是此类数据往往比较混乱,无法满足我们的要求,因此在进行数据分析之前,需要将这些数据进行整理清洗,excel由于将数据的管理 ...

  4. 《javascript高级程序设计》 第25章 新兴的API

    25.1 requestAnimationFrame() 25.1.1 早期动画循环 25.1.2 循环间隔的问题 25.1.3 mozRequestAnimation-Frame.webkitReq ...

  5. HDUOJ--汉诺塔II

    汉诺塔II Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  6. hashtable 实现

    #include <stdlib.h> #include <stdio.h> #include <string.h> typedef struct _hashnod ...

  7. python获取文件的内容

  8. SQL Server数据库(表的创建)

    表的创建 1.创建列(字段):列名+类型 2.设置主键列:能够唯一表示一条数据 3.设置唯一键:设计--索引/键--添加--唯一键(选择列)--确定 唯一键的内容不能重复 4.外键关系:一张表(从表) ...

  9. 转载,javascript 设计模式

    了解JavaScript设计模式我们需要知道的一些必要知识点:(内容相对基础,高手请跳过) 闭包:关于闭包这个月在园子里有几篇不错的分享了,在这我也从最实际的地方出发,说说我的理解. 1.闭包最常用的 ...

  10. 去除Sql Server中回车换行符

    这里使用了,sql 函数.replace(string_expression , string_pattern , string_replacement), 第一个参数:要查找的字段. 第二个参数:要 ...