• Spring3系列4-多个配置文件的整合


    Spring3系列4-多个配置文件的整合

      在大型的Spring3项目中,所有的Bean配置在一个配置文件中不易管理,也不利于团队开发,通常在开发过程中,我们会按照功能模块的不同,或者开发人员的不同,将配置文件分成多个,这样有利于模块的划分。本文将讲述怎样整合多个配置文件,由于Spring3允许使用xml配置和JavaConfig特性两种方式配置,本文也将分别举例。

    一、      加载多个xml文件配置

      例如,项目中有多个xml配置文件:

    1. Spring-Common.xml位于common文件夹下
    2. Spring-Connection.xml位于connection文件夹下
    3. Spring-ModuleA.xml位于moduleA文件夹下

      你可以在代码中加载以上3个xml配置文件

    ApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"Spring-Common.xml","Spring-Connection.xml","Spring-ModuleA.xml"});

      但是这种方法不易组织并且不好维护,最好的方法是在一个单独的xml的配置文件中组织其他所有的xml配置文件。例如,可以创建一个Spring-All-Module.xml文件,然后将其他的xml配置文件导入到Spring-All-Module.xml中,就像下边这样,

    Spring-All-Module.xml

    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
    
        <import resource="common/Spring-Common.xml"/>
        <import resource="connection/Spring-Connection.xml"/>
        <import resource="moduleA/Spring-ModuleA.xml"/>
    </beans>

           现在,你可以在代码中加载一个单独的xml配置文件,如下:

    ApplicationContext context =    new ClassPathXmlApplicationContext(Spring-All-Module.xml);

    二、      加载多个JavaConfig特性配置

      JavaConfig特性配置SpringBean见前文《Spring3系列3-JavaConfig》

      假设有两个JavaConfig的配置:

    1. CustomerConfig.java
    2. SchedulerConfig.java

      你需要管理多个JavaConfig配置的情况下,可以单独创建一个AppConfig.java,然后将其他的配置导入到AppConfig.java中,如下:

    AppConfig.java

    import org.springframework.context.annotation.Configuration;
    import org.springframework.context.annotation.Import;
    
    @Configuration
    @Import({ CustomerConfig.class, SchedulerConfig.class })
    public class AppConfig {
    
    }

    这样,加载时,只需要加载AppConfig.java即可

    ApplicationContext context =
      new AnnotationConfigApplicationContext(AppConfig.class);
  • 相关阅读:
    C++:怎样把一个int转成4个字节?
    安装虚拟机
    [Flux] 1. Development Environment Setup
    [CSS] Animating SVG
    [Node.js] Scraping Dynamic JavaScript Websites with Nightmare
    [React] React Fundamentals: Integrating Components with D3 and AngularJS
    [React] React Fundamentals: with-addons
    [JavaScript] Array.prototype.reduce in JavaScript by example
    [CSS] @keyframes
    [CSS] Transforms
  • 原文地址:https://www.cnblogs.com/leiOOlei/p/3491042.html
Copyright © 2020-2023  润新知