准备工作:
书写一个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");