EnvironmentAware接口的作用

在SpringBoot中的應用

凡註冊到Spring容器內的bean,實現了EnvironmentAware接口重寫setEnvironment方法後,在工程啓動時可以獲得application.properties的配置文件配置的屬性值。

demo演示

直接上代碼,比如我的application.properties文件有如下配置(這裏說明一下SpringBoot應用默認的配置文件名就叫做application.properties,可以直接放在當前項目的根目錄下,或者一個名叫config的子目錄下)
這裏寫圖片描述
再建一個類實現EnvironmentAware接口,其中@Configuration註解在SpringBoot裏面相當於Spring的XML文件裏的beans標籤一樣,而@Bean註解相當於XML文件裏的bean標籤,代表該類會被加載到Spring的IOC容器內。具體代碼如下

 /**
  * * 
  * @ClassName MyProjectc.java
  * @author 沉魚
  * @date 2017年11月28日 下午4:35:39
  */
 @Configuration
 public class MyProjectc implements EnvironmentAware {

    @Override
    public void setEnvironment(Environment environment) {
            String projectName =      environment.getProperty("project.name");
            System.out.println(projectName);
    }
 }  

啓動SpringBoot後,在控制檯會打印
這裏寫圖片描述

具體SpirngBoot整合Mybatis應用

application.properties文件配置

datasource.driverClassName=com.mysql.jdbc.Driver
datasource.url=jdbc:mysql://localhost:3306/myproject?characterEncoding=utf8&serverTimezone=UTC
datasource.username=chenyu
datasource.password=123456

具體javaConfig代碼

  @Configuration 
  public class MyBatisConfig implements EnvironmentAware {
      private Environment environment;
     @Override
     public void setEnvironment(final Environment environment) {
        this.environment = environment;
    }
    /**
     * 創建數據源(數據源的名稱:方法名可以取爲XXXDataSource(),XXX爲數據庫名       稱,該名稱也就是數據源的名稱)
     */
    @Bean
    public DataSource druidDataSource() throws Exception {
        Properties props = new Properties();
        props.put("driverClassName", environment.getProperty("datasource.driverClassName"));
        props.put("url", environment.getProperty("datasource.url"));
        props.put("username", environment.getProperty("datasource.username"));
        props.put("password", environment.getProperty("datasource.password"));
        return DruidDataSourceFactory.createDataSource(props);
    }
    /**
     * 根據數據源創建SqlSessionFactory
     */
    @Bean
    public SqlSessionFactory sqlSessionFactory() throws Exception {
        PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
        SqlSessionFactoryBean fb = new SqlSessionFactoryBean();
        // 指定數據源(這個必須有,否則報錯)
        fb.setDataSource(druidDataSource());
        fb.setTypeAliasesPackage("com.tf56.pushService.dal.domain");
         // 指定mapper文件          fb.setMapperLocations(resolver.getResources("classpath:mapper/*.xml"));
        return fb.getObject();
    }

}
發佈了32 篇原創文章 · 獲贊 28 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章