`
kangsg219
  • 浏览: 123149 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Spring的XML配置文件的十二个最佳方法实践

阅读更多
Spring是一个强大的Java应用框架,它广泛地应用于Java应用程序中,为Plain Old Java Objects(POJO)提供企业级服务。Spring利用依赖注入机制来简化工作,同时提高可测试性。其配置文件(通常是XML格式)中指定了 Spring bean、依赖性以及bean所需的服务。但是,这些XML配置文件既冗长又不实用。对于需要定义大量Spring bean的大型项目来说,它们难以阅读和管理。
在本文中,我将向您展示12种用于Spring XML配置的最佳实践。其中的一些实践与其说是最佳实践,倒不如说是必要实践。注意,其他因素(如域模型的设置)也可能影响XML的配置,但是本文重点研究XML配置的可读性和可管理性。

1。避免使用自动绑定(autowiring)功能
Spring 可以通过bean类的自省自动绑定依赖性,所以不必显式指明bean的属性和构造函数。Bean属性可以通过属性名称或类型匹配来实现自动绑定。构造函数通过类型匹配来实现自动绑定。甚至可以指定自动检测autowiring模式,它可以引导Spring选择一种适当的运行机制。先来看看下面的一个例子:
  
 <bean id="orderService"
        class="com.lizjason.spring.OrderService"
        autowire="byName"/>

OrderService 类的属性名在容器中用于匹配bean实例。自动绑定可能会节省一些键入工作量并减少混乱。但是在现实项目中不应该使用这种方式,因为它牺牲了配置的可读性和可维护性。许多指南和介绍中大肆吹捧自动绑定是Spring的一项极好的特性,而没有提到这一特性所带来的牺牲。依我来看,这就像Spring中的对象池(object-pooling),更大程度上只是宣传的噱头。对于精简XML配置文件来说,它是一个好办法,但它实际上增加了复杂性,尤其是在运行包含大量类声明的项目时。虽然Spring允许混合使用自动绑定和显式绑定,但这会使XML配置更加晦涩难懂。

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>


简洁形式自1.2版本起就可以使用。注意,对于<ref local="...">,没有简洁形式。
简洁形式不但可以节约键入工作量,而且可以使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>

利用type属性来编写会更好一些,如下:
  
 <bean id="billingService"
        class="com.lizjason.spring.BillingService">
        <constructor-arg type="java.lang.String"
            value="lizjason"/>
        <constructor-arg type="int" value="100"/>
    </bean>


使用index可以减少一些代码,但是与type属性相比,它更易于出错且难于阅读。只有在构造函数参数不明确的时候,才应该使用index。

5. 尽可能重用已定义的bean
Spring 提供了一种类似于继承的机制来减少配置信息的复制并简化XML配置。定义一个子类,它就可以从父类那里继承配置信息,而父类实际上成为子类的一个模板。这就是大型项目中所谓的重用。只需在父类bean中设置abstract=true,然后在子bean中指定parent引用。例如:
  
 <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没有指定类或工厂方法,那么这个bean便是抽象的。

6. 在导入时,首选通过ApplicationContext来汇编bean定义

像Ant脚本中的导入一样,Spring的import元素对于汇编模块化的bean定义来说是很有用的。例如:
  
 <beans>
        <import resource="billingServices.xml"/>
        <import resource="shippingServices.xml"/>
        <bean id="orderService"
            class="com.lizjason.spring.OrderService"/>
    <beans>


然 而,相对于使用import在XML配置中进行预汇编,通过ApplicationContext来配置这些bean则显得更加灵活。使用 ApplicationContext的话,XML配置也更易于管理。可以向ApplictionContext构造函数传递一组bean定义,如下:
  
 String[] serviceResources =
        {"orderServices.xml",
        "billingServices.xml",
        "shippingServices.xml"};
    ApplicationContext orderServiceContext = new
        ClassPathXmlApplicationContext(serviceResources);

7. 使用id作为bean标识符
可以指定一个id或名称来作为bean标识符。虽然使用id不能提高可读性,但是它可以利用XML分析程序来对bean引用进行验证。如果由于XML IDREF的约束而不能使用某个id,那么可以使用名称来作为bean的标识符。XML IDREF的约束是:id必须以字母(或者XML规范中定义的标点符号)开头,后面是字母、数字、连字符、下划线、冒号或句点。实际上,很少会遇到XML IDREF约束问题。

8. 在开发阶段使用依赖性检查(dependency-check)

可以在bean定义中为dependency-check属性设置一个非默认值,比如simple、objects或all,以便容器进行依赖性检查。当需要显式或通过自动绑定设置bean的全部属性(或某类属性)时,依赖性检查便显得很有用。
  
 <bean id="orderService"
        class="com.lizjason.spring.OrderService"
        dependency-check="objects">
        <property name="companyName"
            value="lizjason"/>
        <constructor-arg ref="orderDAO"/>
    </bean>


在这个例子中,容器确保为orderService bean设置的属性不是primitives或collections。也可以为所有的bean设置默认依赖性检查,但是我们很少这样做,因为有些bean属性根本就不必设置。

9. 为每个配置文件添加首部注释
最好使用描述性的id和名称来取代XML配置文件中的内置注释。此外,添加一个配置文件首部也很有用,它可以概述文件中所定义的bean。可以选择将描述添加到description标签中。例如:
   
<beans>
        <description>
            This file defines billing service
            related beans and it depends on
            baseServices.xml,which provides
            service bean templates...
        </description>
        ...
    </beans>

使用description标签的一个好处是可以轻松地利用工具从标签中选获取描述内容。

10. 对于更改,团队成员要积极交流
在重构Java代码时,需要随时更新配置文件并通知团队成员。XML配置文件也是代码,它们是应用程序的至关重要的部分,但是它们难于阅读和维护。大部分情况下,需要同时阅读XML配置文件和运行中的Java代码。

11. Setter注入优于构造函数注入
Spring提供了3种类型的依赖注入:构造函数注入(constructor injection)、setter注入(setter injection)和方法注入(method injection)。我们一般只用前两种。
   
<bean id="orderService"
        class="com.lizjason.spring.OrderService">
        <constructor-arg ref="orderDAO"/>
    </bean>

    <bean id="billingService"
        class="com.lizjason.spring.BillingService">
        <property name="billingDAO"
            ref="billingDAO">
    </bean>

在这个例子中,orderService类使用的是构造函数注入,而BillingService类使用的是setter注入。构造函数注入可以确保 bean不会在一个非法状态下被创建,但是setter注入更加灵活且更易于管理,尤其是在类包含许多属性并且其中一些可选的情况下。

12. 不要滥用依赖注入
最 后一点,Spring ApplicationContext可以为您创建Java对象,但并不是所有的Java对象都应通过依赖注入来创建。例如,全局对象不应该通过 ApplicationContext来创建。Spring是一个很棒的框架,但是,就可读性和易管理性而言,如果定义了大量bean,基于XML的配置就可能成为问题。过度使用依赖注入会使XML配置变得复杂且臃肿。要知道,借助于功能强大的IDE(如Eclipse和IntelliJ),Java代码比XML文件更加易读、易维护、易管理。

结束语
XML是通用的Spring配置方式。但如果定义了大量bean,基于XML的配置就会变得冗长而不实用。Spring提供了丰富的配置选项,恰当地利用其中的选项可以使XML配置更清晰,但是,有些选项(如autowiring)往往会降低配置文件的可读性和可维护性。遵循本文中所描述的最佳实践,将有助于您创建出清晰易读的XML配置文件。
分享到:
评论

相关推荐

    Spring中XML配置文件的十二个最佳方法.doc

    本文将详细解析Spring中XML配置文件的十二个最佳实践,主要关注前六个方法。 1. **避免使用自动绑定(Autowiring)** Spring的自动绑定功能允许框架通过类的自省自动注入依赖。虽然可以减少手动配置,但会导致配置...

    Spring XML配置十二个最佳实践

    ### Spring XML配置十二个最佳实践 #### 一、利用自动装配简化配置 在Spring框架中,自动装配(Autowiring)是一种非常实用的功能,它能够帮助我们减少对Bean依赖关系的手动配置工作量。通过设置`autowire`属性,...

    spring配置文件:整理总结Spring中XML配

    本文将详细介绍关于Spring XML配置文件的12个最佳实践,这些实践不仅有助于提高配置文件的可读性和可维护性,还能帮助开发者更好地理解和使用Spring框架。 #### 最佳实践 1. **避免使用自动绑定(Autowiring)** ...

    Spring中XML配置文件的十二个最佳方法[借鉴].pdf

    本文主要探讨了Spring XML配置文件的六个最佳实践,旨在提升代码的可读性、可维护性以及整体项目的结构。以下是这六个方法的详细说明: 1. 避免使用自动绑定(autowiring) 自动绑定允许Spring通过bean类的自省来...

    Spring+SpringMVC+Mybatis整合所需jar包以及xml配置文件配置方式

    5. **XML配置详解**:在Spring的XML配置文件中,你可以定义bean的实例化方式,如构造函数注入、属性注入等。在SpringMVC的配置中,你需要定义视图解析器,如InternalResourceViewResolver,以及处理请求的处理器映射...

    Spring中XML配置的12个技巧

    总结而言,本文讨论了Spring框架中XML配置文件的一些最佳实践。这些技巧不仅有助于提高代码的质量,还能帮助开发者更好地组织和管理大型项目的配置信息。通过避免自动装配、使用清晰的命名规则、采用简化格式、合理...

    Spring Boot技术知识点:如何读取不同路径里的applicationContext.xml配置文件4

    创建一个名为`org.springframework.boot.autoconfigure.EnableAutoConfiguration`的键,并将你的XML配置文件对应的`Configuration`类名作为值添加进去。 3. **自定义BeanDefinitionReader** 你可以创建一个自定义...

    廖雪峰 Spring 2.0 核心技术与最佳实践 高清扫描版

    《Spring 2.0 核心技术与最佳实践》是由知名IT教育家廖雪峰编写的教程,旨在为从初学者到高级工程师提供全面而深入的Spring 2.0框架理解与应用指导。Spring框架是Java开发中的核心工具,尤其在企业级应用中广泛使用...

    基于Spring Cloud Alibaba的Spring Cloud最佳实践设计源码

    该项目为Spring Cloud Alibaba框架下的Spring Cloud最佳实践设计源码,包含178个文件,涵盖113个Java源文件、37个XML配置文件、18个VM模板文件、6个YAML配置文件、3个备份文件和1个SQL脚本文件,旨在展示代码的艺术...

    spring配置最佳实践.zip

    本实践指南将深入探讨Spring配置的最佳实践,旨在帮助开发者优化代码,提高应用的可维护性和可扩展性。 一、XML配置与Java配置的选择 Spring最初是以XML配置为主,但随着版本的更新,Java配置逐渐成为首选。Java...

    Spring全注解project示例 (无web.xml配置)

    同时,这样的配置也便于自动化测试,因为无需处理XML配置文件。 7. **学习路径**:如果你是一个初学者,了解Spring的基础概念(如IoC和AOP)是必要的。然后,你可以逐步学习Spring注解的使用,如`@Controller`、`@...

    Spring 配置文件详解.doc

    在本文中,我们将详细介绍 Spring 配置文件的组成结构、配置方法和最佳实践。 配置文件的简化 在 Spring 配置文件中,属性的定义可以简化为单个标签。例如,以下代码: ```xml &lt;value&gt;fooValue ``` 可以简化...

    Spring各版本核心配置文件备份

    在`Spring各版本核心配置文件备份`这个压缩包中,我们可以找到不同版本的Spring框架使用的配置文件模板。这些文件可以帮助我们了解每个版本中新增的功能、调整的API,以及推荐的最佳实践。例如,从Spring 2.x到3.x的...

    Java EE设计模式:Spring企业级开发最佳实践

    Java EE 设计模式:Spring 企业级开发最佳实践 Java EE 设计模式是指在 Java 企业版(Java Enterprise Edition)中应用的设计模式,旨在提高软件系统的可维护性、可扩展性和可重用性。Spring 是当前最流行的 Java ...

    Spring项目配置文件(整合security、hibernate、fckeditor、jdbc、log4j)

    在本项目中,我们主要关注的是Spring框架的配置,它被广泛用于...在实际开发中,我们还应该遵循最佳实践,比如使用 profiles 分割环境配置,利用注解简化XML配置,以及利用Spring Boot的自动配置特性来简化配置过程。

    spring配置文件加密方法示例

    一个典型的Spring配置文件(如`applicationContext.xml`)是一个XML文档,它包含Bean的定义,这些定义描述了对象的创建方式、它们之间的依赖关系以及如何初始化和销毁这些对象。当Spring容器启动时,它会读取这些...

    spring3.2参考文档

    在Spring 3.2中,增强了对Java配置的支持,使得开发者可以使用Java类替代XML配置文件。 2. **AOP(面向切面编程)**:Spring提供了AOP支持,允许开发者定义和执行横切关注点,如日志、事务管理等。3.2版本进一步...

    整合JAVA框架配置文件

    这通常涉及到XML配置文件、Java配置类或者基于注解的配置。 例如,Spring框架的配置文件(如`applicationContext.xml`)通常用于定义bean、注入依赖、配置数据源、事务管理等。MyBatis的配置文件(`mybatis-config....

    pring配置文件共5页.pdf.zip

    标签"Spring配置文件共5页.pdf"进一步确认了这个文档的主题,它可能包含关于Spring配置的常见问题解答、最佳实践以及如何解决配置中遇到的常见错误。 至于压缩包内的"赚钱项目",这看起来与Spring配置文件的主题不...

    strruts2.1、Spring3.0、Hibernate3.3整合与S2SH的XML文件拆分.docx

    同时,开发者还需要在Spring的配置文件(如`applicationContext.xml`)中定义Action的bean。 **Hibernate3.3配置:** Hibernate是一个流行的ORM(对象关系映射)框架,用于简化数据库操作。在整合中,Hibernate负责...

Global site tag (gtag.js) - Google Analytics