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

Spring 配XML的十二种技巧!

    博客分类:
  • JAVA
阅读更多
Spring 配XML的十二种技巧!
   Spring是一个强有力的java程序框架,其被广泛应用于java的程序中。它用POJO提供了企业级服务。Spring利用依赖注入可以获得简单而有效的测试能力。Spring beans,依赖关系,以及服务所需要的bean都将在配置文件中予以描述,配置文件一般采用XML格式。然而XML配置文件冗长而不易使用,在你进行一个使用了大量bean的大项目中它将变得难以阅读和控制。

    在这篇文章中我将给你展示12种的有关Spring XML配置文件的最佳技巧。它们中的一些具有更多的实际意义,而不仅是最好的技巧。请注意另外一些因素,例如域模型的设计,会影响到XML配置,但是这篇文章更关注于XML配置的可读性和可操控性。

1. 避免使用自动装配

    Spring可以通过bean类的自省来实现自动装配依赖,这样的话你就不必明确地描述bean的属性或者构造函数的参数。根据属性名称活匹配类型,bean属性可以自动进行装配。而构造函数可以根据匹配类型自动装配。你甚至可以设置自动装配进行自动侦测,这样Spring替 你就会选择一个合适的机制。请看下面的例子:
      <bean id="orderService"

        class="com.lizjason.spring.OrderService"

        autowire="byName"/>

    OrderService类的属性名被用来和容器中的一个bean实例进行匹配。自动装配会默默的保存一些类型信息并降低混乱。然而,由于它会牺牲掉这种配置的直观性和可维护性,你在实际的项目中将不会用到它。许多指南和陈述材料都把它吹捧为Spring的一个非常cool的特性,而没有提到它的这个缺点。依我之见,就像Spring的对象池一样,它更多了一些商业味道。它看起来好像可以使XML配置文件更精简一些,但实际上却增加其复杂性,尤其是在你的较大规模的工程中已经定义了很多bean的时候更是如此。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配置更加的清晰。当你的配置文件中存在大量的bean定义时,它可以显著地提高可读性。

4. 尽量使用type而不是index去解决构造函数参数的匹配问题
    当构造函数中有多个同类型的参数时,Spring只允许你使用从0开始的index或者value标签来解决这个问题。请看下面的例子:

    <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可以从它的父bean继承配置信息,本质上这个父bean就像它的子bean的一个模板。这是一个在大型项目中必须使用的特性。所有你要做的就是把父bean的abstract属性置为true,并在子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 bean继承了abstractService bean的属性companyName的值lizjason。注意,如果你为bean声名一个class或工厂方法,这个bean将会默认为abstract

6. 尽量使用ApplicationContext装配bean,而不是用import
    像Ant脚本中imports一样,Spring的import 元素对于模块化bean的装配非常有用,例如:
    <beans>
        <import resource="billingServices.xml"/>
        <import resource="shippingServices.xml"/>
        <bean id="orderService"
            class="com.lizjason.spring.OrderService"/>
    <beans>
    然而,比起在XML中用imports预装配这些bean,利用ApplicationContext来配置它们将更加灵活,也可以使XML配置更加的易于管理。你可以像下面这样传递一个bean定义数组到ApplicationContext的构造函数中:

    String[] serviceResources =
        {"orderServices.xml",
        "billingServices.xml",
        "shippingServices.xml"};
ApplicationContext orderServiceContext = new
ClassPathXmlApplicationContext(serviceResources);



7. 用id来标识bean
    你可以用id或名字作为bean的标识。用id可读性较差,但是它可以影响XML分析器使bean的reference有效。如果id由于XML IDREF约束而无法使用,你可以用name作为bean的标识。XML IDREF约束是指id必须以字母开始(或者是在XML声名了的一个标点符号),后面可以是字母,数字,连字符,下划线,冒号或full stops(不知道怎么翻译好)。在实际应用中很少会遇到XML IDREF约束问题。

8. 在开发阶段使用依赖检查
    你可以为bean的dependency-check属性设置一个值来取代默认的none,比如说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>
在这个例子中,容器将确保这些属性不是privitives或者保证collections是为orderService bean设置的。为所有的bean设置默认的依赖检查是可能的,但这个特性由于有些bean的属性不需要设置而很少使用。

9. 为每个配置文件加一个描述注释
    在XML配置文件中最好使用有描述性的id和name,而不是成堆的注释。另外,加一个文件描述头将会非常有用,这个描述可以概括文件中定义的bean。另一个选择,你可以在description元素中加入描述信息。例如:
[size=large][/size]
    <beans>
        <description>
            This file defines billing service
            related beans and it depends on
            baseServices.xml,which provides
            service bean templates...
        </description>
        ...
    </beans>
用description元素的一个好处就是工具可以很容易的把描述信息从这个元素中提取出来。

10.和team members沟通变更
    当你修改java源码后,要确保更改了配置文件中的相应部分并把这个情况告知你的team members。XML配置文件也是代码,它们是程序的重要组成部分,但它们很难阅读和维护。大多数时间里,你需要同时看XML配置文件和java代码才能知道是怎么回事。

11.setter注入和构造函数注入,优先使用前者
    Spring提供了三种注入方式:构造函数注入,setter注入和方法注入。一般我们使用前两种。

    <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 bean用了构造函数注入,而BillingService bean用了setter注入。构造函数注入可以确保bean正确地构建,但是setter注入更加的灵活和易于控制,特别是当class有多个属性并且它们中的一些是可选的情况是更是如此。

12. 不要滥用注入

    就像前面提到的,Spring的ApplicationContext可以替你创建java对象,但不是所有的java对象都应该通过注入创建。例如,域对象就不应该通过ApplicationContext创建。Spring是一个优秀的框架,但是考虑到可读性和可操控性,基于XML配置的配置会在定义很多bean的时候出现麻烦。过渡使用依赖注入将会使XML配置更加的复杂和冗长。切记,当使用高效的IDE时,例如Eclipse and IntelliJ,java代码更加的易于阅读,维护和管理比使XML文件

结论
   XML是Spring流行的配置格式。存在大量bean定义时,基于XML的配置会变得冗长而不易使用。Spring提供了丰富的配置选项。适当地使用这些选项可以使XML配置更加的清晰,但其它的一些选项,例如自动装配,可能会降低可读性和可维护性。参考本文中提到的这些技巧可能会帮助你创建干净而易读的XML配置文件
分享到:
评论

相关推荐

    Spring 配XML的十二种技巧

    Spring 配XML的十二种技巧

    Spring 配XML的十二种技巧.doc

    在探讨Spring配XML的十二种技巧时,我们深入解析了几个关键点,这些技巧旨在提升Spring框架中XML配置文件的可读性、可维护性和效率。以下是对文章中提到的几点技巧的详细解读: ### 1. 避免使用自动装配 尽管...

    尚硅谷_Spring_代码及PPT

    这份压缩包包含了详细的代码示例和配套的PPT讲解,旨在帮助学习者深入理解并掌握Spring框架的核心功能和使用技巧。 Spring框架是Java企业级应用开发中的主流框架,它以其依赖注入(Dependency Injection,DI)和...

    Spring + Hibernate + Struts 事务配置小例子(带提示框等小技巧)

    现在我总结配出一套,给大家参考参考,可能有不足,请大家多多交流。 附:内有弹出对话框,Action乱码处理和一些好技巧。 2008-5-28 修改: 今天修改了 applicationContext.xml,以后的事务控制就万事大吉了,...

    SPring Framework 2入门代码和封面.rar

    7. **Bean的配置**:Spring支持XML和基于注解两种方式配置Bean。XML配置较传统,而注解配置则更简洁,降低了XML配置的繁琐度。 8. **Spring Test**:Spring提供了一套测试工具集,包括Spring Test和JUnit集成,帮助...

    web框架PPT——Struts 2+Hibernate+MyBatis+Spring 网站开发案例课堂 书籍附带PPT课件

    在现代的Web应用程序开发中,Java Web框架的组合使用已经成为了一种常见的模式,特别是Struts 2、Hibernate、MyBatis和Spring这四个组件的整合,它们分别在MVC架构的不同层面发挥着关键作用。本课程围绕这个组合展开...

    Spring2.5开发简明教程中文版(1-4章有书签)

    通过实际操作,读者可以快速掌握Spring的使用技巧,并能够将其应用到自己的项目中。 总的来说,《Spring2.5开发简明教程中文版》是一份非常适合初学者入门的教程,它不仅讲解了Spring的基础知识,还提供了丰富的...

    Spring Boot 视频

    2. **起步驱动配置**:解释Spring Boot如何通过 starter 包实现自动化配置,减少XML配置。 3. **Actuator**:讲解Actuator组件如何提供健康检查、应用信息和监控功能。 4. **Spring Boot应用结构**:讨论标准的...

    基于ssm的公司配件库存管理系统源码数据库.zip

    在系统实现过程中,Spring通过XML配置或注解方式管理Bean,实现依赖注入,降低了组件间的耦合度。SpringMVC接收HTTP请求,调用业务逻辑处理,然后返回响应。MyBatis通过Mapper接口和XML映射文件,将SQL语句与Java...

    疯狂SpringBoot2配套代码

    它通过`@EnableAutoConfiguration`注解,根据项目中的依赖自动配置Bean,省去了大量的XML配置工作。 2. **起步依赖(Starters)**:SpringBoot2提供了各种起步依赖,如`spring-boot-starter-web`、`spring-boot-...

    spring-practice

    标题“spring-practice”指的是一个关于Spring框架的实践项目,可能是为了帮助学习者掌握Spring的核心概念和使用技巧。Spring是一个广泛应用于企业级Java开发的开源框架,它简化了应用程序的构建,提供了依赖注入、...

    Maven应用实战源码 配套源码

    《Maven应用实战》这本书由杨式文和孙会军编著,提供了丰富的实践案例和详尽的解析,帮助读者深入理解并掌握Maven的使用技巧。本篇将基于该书的配套源码,探讨Maven的核心概念和关键功能。 首先,我们需要了解Maven...

    ssh框架jar包整合

    4. 整合过程中的配置文件,如struts.xml、spring-context.xml、hibernate.cfg.xml等的编写。 5. 整合过程中可能出现的问题及解决方案,如类加载冲突、事务管理配置等。 6. 使用Eclipse或IntelliJ IDEA等IDE进行项目...

    JSP开发技术大全 源码

    mail组件、程序日志组件、JavaScript脚本语言、CSS样式、XML入门技术、在JSP中应用Ajax技术、在JSP中应用DOM解析XML、在JSP中应用JDOM解析XML、在JSP中应用SAX解析XML、EL表达式、JSTL标签库、自定义标签、Hibernate...

    Java项目实战-挖掘机配件营销系统(缺少数据库文件,找程兵要原始的)(附源码,部署说明).zip

    在缺少数据库文件的情况下,MyBatis的XML映射文件或注解形式的SQL语句是系统与数据库交互的重要部分。 4. **JDBC**:尽管MyBatis提供了更高级的数据库操作方式,但基础的Java Database Connectivity (JDBC)仍会作为...

    《Web服务开发学习实录》源代码

    在Web服务中,数据交换通常涉及XML和JSON两种格式。XML是结构化的数据表示法,适用于复杂的结构。JSON则更轻量级,易于解析和生成,更适合浏览器环境。源代码中可能包括XML和JSON之间的转换示例。 4. SOAP与REST...

    MyBatis实战入门配套资料.zip

    - Mapper接口:提供了一种面向接口的编程方式,通过Mapper接口与SQL映射文件的绑定,使得业务逻辑代码更简洁。 - 映射器:MyBatis的映射器实现了SQL的动态执行,可以处理复杂的查询和更新需求。 2. **MyBatis主要...

    JSP开发技术大全 JSP

    mail组件、程序日志组件、JavaScript脚本语言、CSS样式、XML入门技术、在JSP中应用Ajax技术、在JSP中应用DOM解析XML、在JSP中应用JDOM解析XML、在JSP中应用SAX解析XML、EL表达式、JSTL标签库、自定义标签、Hibernate...

    jsp 开发技术大全

    mail组件、程序日志组件、JavaScript脚本语言、CSS样式、XML入门技术、在JSP中应用Ajax技术、在JSP中应用DOM解析XML、在JSP中应用JDOM解析XML、在JSP中应用SAX解析XML、EL表达式、JSTL标签库、自定义标签、Hibernate...

Global site tag (gtag.js) - Google Analytics