1. 程式人生 > >Spring的Java配置方式、讀取配置檔案資訊

Spring的Java配置方式、讀取配置檔案資訊

  1. Spring的發展
    1. Spring1.x 時代

在Spring1.x時代,都是通過xml檔案配置bean,隨著專案的不斷擴大,需要將xml配置分放到不同的配置檔案中,需要頻繁的在java類和xml配置檔案中切換。

    1. Spring2.x時代

隨著JDK 1.5帶來的註解支援,Spring2.x可以使用註解對Bean進行申明和注入,大大的減少了xml配置檔案,同時也大大簡化了專案的開發。

 

那麼,問題來了,究竟是應該使用xml還是註解呢?

 

最佳實踐:

  1. 應用的基本配置用xml,比如:資料來源、資原始檔等;
  2. 業務開發用註解,比如:Service中注入bean等;
    1. Spring3.x到Spring4.x

從Spring3.x開始提供了Java配置方式,使用Java配置方式可以更好的理解你配置的Bean,現在我們就處於這個時代,並且Spring4.x和Spring boot都推薦使用java配置的方式。

  1. Spring的Java配置方式

Java配置是Spring4.x推薦的配置方式,可以完全替代xml配置。

    1. @Configuration 和 @Bean

Spring的Java配置方式是通過 @Configuration 和 @Bean 這兩個註解實現的:

1、@Configuration 作用於類上,相當於一個xml配置檔案;

2、@Bean 作用於方法上,相當於xml配置中的<bean>;

    1. 示例

該示例演示了通過Java配置的方式進行配置Spring,並且實現了Spring IOC功能。

      1. 建立工程以及匯入依賴

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

   <modelVersion>4.0.0</modelVersion>

   <groupId>cn.itcast.springboot</groupId>

   <artifactId>itcast-springboot</artifactId>

   <version>1.0.0-SNAPSHOT</version>

   <packaging>war</packaging>

 

   <dependencies>

      <dependency>

         <groupId>org.springframework</groupId>

         <artifactId>spring-webmvc</artifactId>

         <version>4.3.7.RELEASE</version>

      </dependency>

      <!-- 連線池 -->

      <dependency>

         <groupId>com.jolbox</groupId>

         <artifactId>bonecp-spring</artifactId>

         <version>0.8.0.RELEASE</version>

      </dependency>

   </dependencies>

   <build>

      <finalName>${project.artifactId}</finalName>

      <plugins>

         <!-- 資原始檔拷貝外掛 -->

         <plugin>

            <groupId>org.apache.maven.plugins</groupId>

            <artifactId>maven-resources-plugin</artifactId>

            <configuration>

               <encoding>UTF-8</encoding>

            </configuration>

         </plugin>

         <!-- java編譯外掛 -->

         <plugin>

            <groupId>org.apache.maven.plugins</groupId>

            <artifactId>maven-compiler-plugin</artifactId>

            <configuration>

               <source>1.7</source>

               <target>1.7</target>

               <encoding>UTF-8</encoding>

            </configuration>

         </plugin>

      </plugins>

      <pluginManagement>

         <plugins>

            <!-- 配置Tomcat外掛 -->

            <plugin>

               <groupId>org.apache.tomcat.maven</groupId>

               <artifactId>tomcat7-maven-plugin</artifactId>

               <version>2.2</version>

            </plugin>

         </plugins>

      </pluginManagement>

   </build>

</project>

      1. 編寫User物件

public class User {

 

    private String username;

 

    private String password;

 

    private Integer age;

 

    public String getUsername() {

        return username;

    }

 

    public void setUsername(String username) {

        this.username = username;

    }

 

    public String getPassword() {

        return password;

    }

 

    public void setPassword(String password) {

        this.password = password;

    }

 

    public Integer getAge() {

        return age;

    }

 

    public void setAge(Integer age) {

        this.age = age;

    }

 

}

 

      1. 編寫UserDAO 用於模擬與資料庫的互動

public class UserDAO {

   

    public List<User> queryUserList(){

        List<User> result = new ArrayList<User>();

        // 模擬資料庫的查詢

        for (int i = 0; i < 10; i++) {

            User user = new User();

            user.setUsername("username_" + i);

            user.setPassword("password_" + i);

            user.setAge(i + 1);

            result.add(user);

        }

        return result;

    }

 

}

      1. 編寫UserService 用於實現User資料操作業務邏輯

@Service

public class UserService {

 

    @Autowired // 注入Spring容器中的bean物件

    private UserDAO userDAO;

 

    public List<User> queryUserList() {

        // 呼叫userDAO中的方法進行查詢

        return this.userDAO.queryUserList();

    }

 

}

      1. 編寫SpringConfig 用於例項化Spring容器

@Configuration //通過該註解來表明該類是一個Spring的配置,相當於一個xml檔案

@ComponentScan(basePackages = "cn.itcast.springboot.javaconfig") //配置掃描包

public class SpringConfig {

   

    @Bean // 通過該註解來表明是一個Bean物件,相當於xml中的<bean>

    public UserDAO getUserDAO(){

        return new UserDAO(); // 直接new物件做演示

    }

   

}

      1. 編寫測試方法 用於啟動Spring容器

public class Main {

   

    public static void main(String[] args) {

        // 通過Java配置來例項化Spring容器

        AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);

       

        // Spring容器中獲取Bean物件

        UserService userService = context.getBean(UserService.class);

       

        // 呼叫物件中的方法

        List<User> list = userService.queryUserList();

        for (User user : list) {

            System.out.println(user.getUsername() + ", " + user.getPassword() + ", " + user.getPassword());

        }

       

        // 銷燬該容器

        context.destroy();

    }

 

}

 

 

      1. 測試效果

 

 

從以上的示例中可以看出,使用Java程式碼就完美的替代xml配置檔案,並且結構更加的清晰。

 

      1. 讀取外部的資源配置檔案
      2. @Configuration //通過該註解來表明該類是一個Spring的配置,相當於一個xml檔案

        @ComponentScan(basePackages = "cn.itcast.springboot.javaconfig") //配置掃描包

        @PropertySource(value= {"classpath:jdbc.properties"})

        public class SpringConfig {

           

            @Value("${jdbc.url}")

            private String jdbcUrl;

           

            @Bean // 通過該註解來表明是一個Bean物件,相當於xml中的<bean>

            public UserDAO getUserDAO(){

                return new UserDAO(); // 直接new物件做演示

            }

           

        }

           

  1. 如何配置多個配置檔案?
  2. 如果配置的配置檔案不存在會怎麼樣?
      1. 配置資料庫連線池
      2.  

匯入依賴:

<!-- 連線池 -->

      <dependency>

         <groupId>com.jolbox</groupId>

         <artifactId>bonecp-spring</artifactId>

         <version>0.8.0.RELEASE</version>

      </dependency>

 

jdbc檔案:

 

@Value("${jdbc.url}")

    private String jdbcUrl;

 

    @Value("${jdbc.driverClassName}")

    private String jdbcDriverClassName;

 

    @Value("${jdbc.username}")

    private String jdbcUsername;

 

    @Value("${jdbc.password}")

    private String jdbcPassword;

 

    @Bean(destroyMethod = "close")

    public DataSource dataSource() {

        BoneCPDataSource boneCPDataSource = new BoneCPDataSource();

        // 資料庫驅動

        boneCPDataSource.setDriverClass(jdbcDriverClassName);

        // 相應驅動的jdbcUrl

        boneCPDataSource.setJdbcUrl(jdbcUrl);

        // 資料庫的使用者名稱

        boneCPDataSource.setUsername(jdbcUsername);

        // 資料庫的密碼

        boneCPDataSource.setPassword(jdbcUsername);

        // 檢查資料庫連線池中空閒連線的間隔時間,單位是分,預設值:240,如果要取消則設定為0

        boneCPDataSource.setIdleConnectionTestPeriodInMinutes(60);

        // 連線池中未使用的連結最大存活時間,單位是分,預設值:60,如果要永遠存活設定為0

        boneCPDataSource.setIdleMaxAgeInMinutes(30);

        // 每個分割槽最大的連線數

        boneCPDataSource.setMaxConnectionsPerPartition(100);

        // 每個分割槽最小的連線數   

        boneCPDataSource.setMinConnectionsPerPartition(5);

        return boneCPDataSource;

}