Spring配置文件是用于指导Spring工厂进行Bean生产、依赖关系注入(装配)及Bean实例分发的"图纸"。Java EE程序员必须学会并灵活应用这份"图纸"准确地表达自己的"生产意图"。Spring配置文件是一个或多个标准的XML文档,applicationContext.xml是Spring的默认配置文件,当容器启动时找不到指定的配置文档时,将会尝试加载这个默认的配置文件。
下面列举的是一份比较完整的配置文件模板,文档中各XML标签节点的基本用途也给出了详细的解释,这些XML标签节点在后续的知识点中均会用到,熟练掌握了这些XML节点及属性的用途后,为我们动手编写配置文件打下坚实的基础。
1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans //整个配置的根节点,包含一个或者多个bean元素 3 4 //最基本的命名空间定义 5 xmlns="http://www.springframework.org/schema/beans" 6 7 //最基本的命名空间定义 8 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 9 10 //启动自动扫描或注解装配的命名空间 11 xmlns:context="http://www.springframework.org/schema/context" 12 13 //启用AOP功能的命名空间 14 xmlns:aop="http://www.springframework.org/schema/aop" 15 16 //启用声明事务的命名空间 17 xmlns:tx="http://www.springframework.org/schema/tx"
18 //与上述命名空间定义相配套的schema定义文件的装载路径 19 xsi:schemaLocation="http://www.springframework.org/schema/beans 20 http://www.springframework.org/schema/beans/spring-beans-2.5.xsd 21 http://www.springframework.org/schema/context 22 http://www.springframework.org/schema/context/spring-context-2.5.xsd 23 http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd 24 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> 25 26 <!-- 配置开启注解处理器 --> 27 <context:annotation-config/> 28 29 <!--开启组件自动扫描,扫描路径由base-package属性指定,代表扫描指定包名以及其子包 --> 30 <context:component-scan base-package="test"></context:component-scan> 31 32 <!--开启基于@AspectJ切面的注解处理器--> 33 <aop:aspectj-autoproxy/> 34 35 <!-- 引入配置文件,文件位置由location属性指定 --> 36 <context:property-placeholder location="xxx"/> 37 38 <!--使用class属性指定类的默认构造方法创建一个单实例Bean,名称由id属性指定 39 1.scope属性为 40 prototype时表示每次将生成新的实例,即原型模式 41 singleton时表示在每个Spring IOC容器中该bean定义只有一个对象实例 42 2.init-method:初始化时调用的方法名 43 3.destroy-method:对象销毁时调用的方法名 44 --> 45 <bean id="Bean实例名称" class="Bean类全名称" scope="prototype" init-method="init" destroy-method="close"> 46 47 <property name="Bean类中的属性名称" value="直接指定属性值"/> 48 49 <property name="Bean类中的属性名称" ref="要引用的Bean名称"/> 50 51 <property name="Bean类中的属性名称"> 52 <!--创建一个内部匿名Bean实例赋值给指定的属性,该匿名Bean实例无法被外界访问--> 53 <bean class="Bean类全名"/> 54 </property> 55 56 <property name="Bean类中的Set类型属性名称"> 57 <!-- 58 set标签用于创建一个Set类型的实例赋值给指定的Set类型属性,Set实例中的元素 59 通过value或ref子标签指定。对于基本数据类型的元素可由value标签生成,如果需 60 要引用其他Bean实例作为Set元素的话,可由ref标签指定。 61 --> 62 <set> 63 <value>要设置到set中的元素</value> 64 <ref bean="要引用的Bean名称"/> 65 </set> 66 </property> 67 68 <property name="Bean类中的List类型属性名称"> 69 <!-- 70 list标签用于创建一个List类型的实例赋值给指定的List类型属性,List实例中的元素 71 通过value或ref子标签指定。对于基本数据类型的元素可由value标签生成,如果需要引 72 用其他Bean实例作为List元素的话,可以由ref标签指定。 73 --> 74 <list> 75 <value>要设置到list中的元素</value> 76 <ref bean="要引用的Ben名称"/> 77 </list> 78 </property> 79 80 <property name="Bean类中的Map类型属性名称"> 81 <!-- 82 map标签用于创建一个Map类型的实例赋值给指定的Map类型属性,Map实例中的元素通过 83 entry标签指定。Map元素的键由entry标签的key属性直接指定,值则可由value或ref子 84 标签的key属性直接指定。对于基本数据类型的元素可由value标签生成,如果需要引用 85 其他Bean实例作为List元素的话,可以由ref标签指定。 86 --> 87 <map> 88 <entry key="map元素的key"> 89 <value>map元素的value</value> 90 </entry> 91 <entry key="map元素的key"> 92 <ref bean="要引用的Ben名称"/> 93 </entry> 94 </map> 95 </property> 96 97 <property name="Bean类中的Properties类型属性名称"> 98 <!-- 99 创建一个Properties类型的实例赋值给指定的Properties类型属性 100 --> 101 <props> 102 <!--Properties实例中的元素由prop标签生成,属性项元素的键由key属性指定,属性元素 103 的值可直接放置在prop标签中--> 104 <prop key="properties元素的key">properties元素的value</prop> 105 </props> 106 </property> 107 108 <property name="Bean类中要初始化为null的属性名称"> 109 <null/><!--null标签用于给需要赋值为null值得属性进行赋null值--> 110 </property> 111 112 <!-- 113 通过传入相应的构造参数进行Bean实例化,constructor-arg标签用于指定一个构造参数,其index 114 属性标明当前是第几个构造参数(从0开始),type属性声明构造参数的类型,构造参数的值如果是基 115 本类型可由value属性值直接指定,如果是对象的引用,则由ref属性指定。 116 --> 117 <constructor-arg index="从0开始的序号" type="构造参数的类型" value="构造参数的值"/> 118 <constructor-arg index="从0开始的序号" type="构造参数的类型" ref="要引用的Bean名称"/> 119 </bean> 120 121 <!--配置切面--> 122 <bean id="目标对象名称" class="目标对象全名"/> 123 <bean id="切面实例名称" class="切面类全名"/> 124 <aop:config> 125 <aop:aspect id="切面id" ref="要引用的切面实例名称"> 126 <aop:pointcut id="切入点名称" expression="切入点正则表达式"/> 127 <aop:before pointcut-ref="切入点名称" method="切面类中用作前置通知的方法名"/> 128 <aop:after-returing pointcut-ref="切入点名称" method="切面类中用作后置通知的方法名"/> 129 <aop:after-throwing pointcut-ref="切入点名称" method="切面类中用作异常通知的方法名"/> 130 <aop:after pointcut-ref="切入点名称" method="切面类中用作最终通知的方法名"/> 131 <aop:around pointcut-ref="切入点名称" method="切面类中用作环绕通知的方法名"/> 132 </aop:aspect> 133 </aop:config> 134 135 <!-- 配置事务管理器 --> 136 <bean id="事务管理器实例名称" class="事务管理器类全名"> 137 <property name="数据源属性名称" ref="要引用的数据源实例名称"> 138 </bean> 139 140 <!-- 配置一个事务通知 --> 141 <tx:advice id="" transaction-manager=""> 142 <tx:attributes> 143 <!-- 方法以get开头的,不使用事务 --> 144 <tx:method name="get*" read-only="true" propagation="NOT_SUPPORTED"/> 145 <!-- 其他方法以默认事务进行 --> 146 <tx:method name="*" /> 147 </tx:attributes> 148 </tx:advice> 149 150 <!-- 使用AOP技术实现事务管理 --> 151 <aop:config> 152 <aop:pointcut id="事务切入点名称" expression="事务切入点正则表达式"/> 153 <aop:advisor advice-ref="事务通知名称" pointcut-ref="事务切入点名称"/> 154 </aop:config> 155 156 <!--使用基于注解方式配置事务, --> 157 <tx:annotation-driven transaction-manager="事务管理器Bean的id"/> 158 159 </beans>