在这篇文章里,对于Spring XML的配置,我将向你展示12种比较好的实践。其中的一些实践不仅是好的实践,更是必要的实践。除此以外,还有其他因素,例如领域模型的设计,都能影响XML的配置,但是这篇文章重点研究XML配置的易读性和易管理性。
1。不要使用autowiring
Spring 可以通过类的自省来自动绑定其依赖部分,使得你不必明确指明bean的属性和构造器。Bean的属性可以通过属性名称或类型匹配来实现自动绑定。构造器通过类型匹配来实现自动绑定。你甚至可以指定自动检测自动绑定模式,它可以引导Spring选择一种适当的运行机制。先来看看下面的一个例子:
| 以下是引用片段: < bean id="orderService" class="com.lizjason.spring.OrderService" autowire="byName"/> |
2.使用通俗的命名
这个方式对于Java编码也一样适用。在工程中使用清晰的、描述性的、协调的通俗名称对于开发者理解XML配置是十分有益的。例如对于bean ID,你可以根据通俗的Java类名来命名它。对于例子中OrderServiceDAO的bean ID命名为orderServiceDAO。对于大的工程,你可以在bean ID前面加上包名作为前缀。
3. 使用简洁的形式
简洁形式避免了冗长,是因为它从子元素中将属性值和参考写到属性中。例如下面的例子:
| 以下是引用片段: < bean id="orderService" class="com.lizjason.spring.OrderService"> < property name="companyName"> < value>lizjason< /value> < /property> < constructor-arg> < ref bean="orderDAO"> < /constructor-arg> < /bean> 可以使用简洁形式将上述代码重写为: < bean id="orderService" class="com.lizjason.spring.OrderService"> < property name="companyName" value="lizjason"/> < constructor-arg ref="orderDAO"/> < /bean> |
简洁形式不但可以节约你的打字,而且可以使XML配置文件清晰。它最引人注目的是当在一个配置文件中有大量定义的类时可以提高易读性。
4. 对于构造器参数匹配,类型名比序号好。
当一个构造器含有一个以上的同种类型的参数,或者属性值的标签已经被占用时,Spring允许你使用从0计数的序号来解决这些会带来混淆的问题。例如:
| 以下是引用片段: < bean id="billingService" class="com.lizjason.spring.BillingService"> < constructor-arg index="0" value="lizjason"/> < constructor-arg index="1" value="100"/> < /bean> |
像下面这样,利用类型属性来编写会更好一些:
| 以下是引用片段: < bean id="billingService" class="com.lizjason.spring.BillingService"> < constructor-arg type="java.lang.String" value="lizjason"/> < constructor-arg type="int" value="100"/> < /bean> |
使用索引可以稍稍减少一些冗长,但是和使用类型属性相比,它还是有容易发生错误的倾向和难于阅读的缺点。你应该只在构造器参数不明确的时候,才使用索引这一方法。
5. 尽可能重用已定义过的bean
Spring 提供一种类似继承一样的机制来减少配置信息的复制并简化XML配置。定义一个子类可以从它父类那里继承配置信息,而父类实质上作为子类的一个模板。这就是大工程中所谓的重用。你所需要做的就是在父类bean中设置abstract=true,然后在子bean注明它自己的父类bean。例如:
| 以下是引用片段: < bean id="abstractService" abstract="true" class="com.lizjason.spring.AbstractService"> < property name="companyName" value="lizjason"/> < /bean> < bean id="shippingService" parent="abstractService" class="com.lizjason.spring.ShippingService"> < property name="shippedBy" value="lizjason"/> < /bean> ShippingService类从abstractService类那里继承companyName属性的值??lizjason。如果你没有为一个bean指明类或factory方法,那么这个bean便是抽象的。 6. 尽量使用ApplicationContext来装配定义的bean 像在Ant脚本中的引用一样,Spring的引用对于装配模块化的bean来说是很有用的。例如: < beans> < import resource="billingServices.xml"/> < import resource="shippingServices.xml"/> < bean id="orderService" class="com.lizjason.spring.OrderService"/> < beans> |