從spring-boot開始,已經支持yml文件形式的配置,@ConfigurationProperties的大致作用就是通過它可以把properties或者yml配置直接轉成對象
@Component注解表明是組件,可被自動發現,@ConfigurationProperties注解之前是location屬性表明配置文件位置,prefix表示讀取的配置信息的前綴,但新版本中廢除了location屬性(網上說是1.5.2之后),故只寫前綴,默認讀取application.yml中數據。重點!!一定要在這個類中寫getter和setter,否則配置中的屬性值無法自動注入
例如:
配置文件: sms.url=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX sms.appkey=XXXXXXXXXXXXXXXXXXXXXXXXXXXXX sms.secret=XXXXXXXXXXXXXXXXXXXXXXXXXXXXX sms.signName=XXXXXXXXXXXXXXXXXXXXXXXXXXX sms.tplCode=XXXXXXXXXXXXXXXXXXXXXXXXXXXX sms.type=normal
JAVA代碼: @Component @ConfigurationProperties(prefix = "sms") public class SmsSettings { private String url =""; private String appkey =""; private String secret =""; private String signName =""; private String tplCode =""; private String type =""; private String open =""; private String tplCode2 =""; public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } public String getAppkey() { return appkey; } public void setAppkey(String appkey) { this.appkey = appkey; } public String getSecret() { return secret; } public void setSecret(String secret) { this.secret = secret; } public String getSignName() { return signName; } public void setSignName(String signName) { this.signName = signName; } public String getTplCode() { return tplCode; } public void setTplCode(String tplCode) { this.tplCode = tplCode; } public String getType() { return type; } public void setType(String type) { this.type = type; } public String getOpen() { return open; } public void setOpen(String open) { this.open = open; } public String getTplCode2() { return tplCode2; } public void setTplCode2(String tplCode2) { this.tplCode2 = tplCode2; } }
通過注解@ConfigurationProperties來配置redis
@Configuration @EnableAutoConfiguration public class RedisConfig { @Bean @ConfigurationProperties(prefix="spring.redis.poolConfig") public JedisPoolConfig getRedisConfig(){ JedisPoolConfig config = new JedisPoolConfig(); return config; } @Bean @ConfigurationProperties(prefix="spring.redis") public JedisConnectionFactory getConnectionFactory(){ JedisConnectionFactory factory = new JedisConnectionFactory(); factory.setUsePool(true); JedisPoolConfig config = getRedisConfig(); factory.setPoolConfig(config); return factory; } @Bean public RedisTemplate<?, ?> getRedisTemplate(){ RedisTemplate<?,?> template = new StringRedisTemplate(getConnectionFactory()); return template; } }
1.添加pom依賴
1
2
3
4
5
|
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>
true
</optional>
</dependency>
|
2.application.yml文件中添加需要配置的屬性,注意縮進
1
2
3
4
5
|
Myyml:
username: cs
password:
123456
url: jdbc:mysql:
//localhost:3306/test
driver: com.mysql.jdbc.Driver
|
3.新建一個類,@Component注解表明是組件,可被自動發現,@ConfigurationProperties注解之前是location屬性表明配置文件位置,prefix表示讀取的配置信息的前綴,但新版本中廢除了location屬性(網上說是1.5.2之后),故只寫前綴,默認讀取application.yml中數據。重點!!一定要在這個類中寫getter和setter,否則配置中的屬性值無法自動注入
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
package
com.cs.background.util;
import
lombok.ToString;
import
org.springframework.boot.context.properties.ConfigurationProperties;
import
org.springframework.context.annotation.PropertySource;
import
org.springframework.stereotype.Component;
@Component
@ConfigurationProperties
(prefix =
"Myyml"
)
public
class
User{
//數據庫連接相關
private
String url;
private
String driver;
private
String username;
private
String password;
public
String getUrl() {
return
url;
}
public
void
setUrl(String url) {
this
.url = url;
}
public
String getDriver() {
return
driver;
}
public
void
setDriver(String driver) {
this
.driver = driver;
}
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;
}
}
|
4.Controller類中執行自動注入,獲取屬性
1
2
3
4
5
|
//自動注入
@Autowired
private
User user;<br>
//方法體內獲取屬性值
String url=user.getUrl();<br>System.out.print(url);
|
5.啟動springboot入口類,調用對應controller對應的方法,控制台打印獲取的值。