SpringBoot知识点(1)——Springboot中读取配置文件的几种方式

准备工作:

书写一个jdbc.properties 文件,编写 jdbc 属性:
jdbc.driverClassName=com.mysql.jdbc.Driver 
jdbc.url=jdbc:mysql://127.0.0.1:3306/user 
jdbc.username=root 
jdbc.password=123456

(1):@Value + @PropertySource     注意:@PropertySource不支持yml文件读取。

第一种:
@ConfigurationProperties(prefix = "jdbc")
@PropertySource("classpath:jdbc.properties") 
public class JdbcConfig { 
    String url; 
    String driverClassName;
    String username; 
    String password; 
//....
}

第二种:
@Configuration 
@PropertySource("classpath:jdbc.properties") 
public class JdbcConfig { 
    @Value("${jdbc.url}") 
    String url; 
    @Value("${jdbc.driverClassName}") 
    String driverClassName;
    @Value("${jdbc.username}") 
    String username; 
    @Value("${jdbc.password}") 
    String password; 
  @Bean 
  public DataSource dataSource() {
      DruidDataSource dataSource = new DruidDataSource(); 
      dataSource.setUrl(url); 
      dataSource.setDriverClassName(driverClassName); 
      dataSource.setUsername(username); 
      dataSource.setPassword(password); 
      return dataSource; 
   } 
}

讲解:
@Configuration :声明我们 JdbcConfig 是一个配置类
@PropertySource :指定属性文件的路径是: 
classpath:jdbc.properties
通过 @Value 为属性注入值
通过@Bean将 dataSource() 方法声明为一个注册Bean的方法,Spring会自动调用该方法,将方法的返回值加入Spring容器中。然后我们就可以在任意位置通过 @Autowired 注入DataSource了!
@Autowired 
private DataSource dataSource;

(2)Springboot提供的新属性(@ConfigurationProperties + @EnableConfigurationProperties支持各种java基本数据类型及复杂类型的注入。

注意:我们需要把jdbc.properties名称改为application.properties,这是SpringBoot默认读取的属性文件名。

改成Application.yml后,格式变成以下:


jdbc:
    driverClassName=com.mysql.jdbc.Driver 
    url=jdbc:mysql://127.0.0.1:3306/user 
    username=root 
    password=123456
@ConfigurationProperties(prefix = "jdbc") 
public class JdbcProperties { 
    private String url; 
    private String 
    driverClassName; 
    private String username; 
    private String password; 
    // getters 和 setters 
}

在类上通过@ConfigurationProperties注解声明当前类为属性读取类prefix="jdbc" 读取属性文件中,前缀为jdbc的值。在类上定义各个属性,名称必须与属性文件中 jdbc. 后面部分一致.
@Configuration
@EnableConfigurationProperties(JdbcProperties.class) 
public class JdbcConfig { 
    @Bean 
    public DataSource dataSource(JdbcProperties jdbc) { 
        DruidDataSource dataSource = new DruidDataSource(); 
        dataSource.setUrl(jdbc.getUrl()); 
        dataSource.setDriverClassName(jdbc.getDriverClassName());                             
        dataSource.setUsername(jdbc.getUsername()); 
        dataSource.setPassword(jdbc.getPassword()); 
        return dataSource; 
    } 
}


通过 @EnableConfigurationProperties(JdbcProperties.class) 来声明要使用JdbcProperties 这个类的对象,然后你可以通过以下方式注入JdbcProperties;
(1)@Autowired注入
    @Autowired 
    private JdbcProperties prop;
(2)构造函数注入
    private JdbcProperties prop; 
    public JdbcConfig(Jdbcproperties prop){ 
        this.prop = prop; 
    }
(3)声明有@Bean的方法参数注入
    @Bean 
    public Datasource dataSource(JdbcProperties prop){ 
    // ...
     }

(3)可以更直接的使用 @ConfigurationProperties

注意:使用的前提是:该类必须有对应属性的set方法!

@Configuration
public class JdbcConfig { 
    @Bean 
    @ConfigurationProperties(prefix = "jdbc")
    public DataSource dataSource(JdbcProperties jdbc) { 
        DruidDataSource dataSource = new DruidDataSource(); 
        return dataSource; 
    } 
}

(4)Environment读取方式 ,所有加载出来的配置都可以通过Environment注入获取到。

@Autowired
private Environment env;

String serverPort = env.getProperty("server.port");

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值