注意:配置文件中的字符串不要有下划線 .配置中 key不能帶下划線,value可以
錯誤的.不能讀取的例子:
mySet .ABAP_AS_POOLED = ABAP_AS_WITH_POOL
不要帶下划線,正確的例子
mySet.ABAPASPOOLED = ABAP_AS_WITH_POOL
(下划線的坑,坑了我兩天..特此紀念)
讀取核心配置文件
核心配置文件是指在resources根目錄下的application.properties或application.yml配置文件,讀取這兩個配置文件的方法有兩種,都比較簡單。
核心配置文件application.properties內容如下:
server.port=9090
test.msg=Hello World Springboot!
- 1
- 2
- 3
- 使用
@Value方式(常用):
@RestController
public class WebController {
@Value("${test.msg}")
private String msg;
@RequestMapping(value = "index", method = RequestMethod.GET)
public String index() {
return "The Way 1 : " +msg;
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
注意:在@Value的${}中包含的是核心配置文件中的鍵名。在Controller類上加@RestController表示將此類中的所有視圖都以JSON方式顯示,類似於在視圖方法上加@ResponseBody。
訪問:http://localhost:9090/index 時將得到The Way 1 : Hello World Springboot!
- 使用
Environment方式
@RestController
public class WebController {
@Autowired
private Environment env;
@RequestMapping(value = "index2", method = RequestMethod.GET)
public String index2() {
return "The Way 2 : " + env.getProperty("test.msg");
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
注意:這種方式是依賴注入Evnironment來完成,在創建的成員變量private Environment env上加上@Autowired注解即可完成依賴注入,然后使用env.getProperty("鍵名")即可讀取出對應的值。
訪問:http://localhost:9090/index2 時將得到The Way 2 : Hello World Springboot!
讀取自定義配置文件
為了不破壞核心文件的原生態,但又需要有自定義的配置信息存在,一般情況下會選擇自定義配置文件來放這些自定義信息,這里在resources/config目錄下創建配置文件my-web.properties
resources/config/my-web.properties內容如下:
web.name=zslin
web.version=V 1.0
web.author=393156105@qq.com
- 1
- 2
- 3
創建管理配置的實體類:
@ConfigurationProperties(locations = "classpath:config/my-web.properties", prefix = "web")
@Component
public class MyWebConfig {
private String name;
private String version;
private String author;
public String getAuthor() {
return author;
}
public String getName() {
return name;
}
public String getVersion() {
return version;
}
public void setAuthor(String author) {
this.author = author;
}
public void setName(String name) {
this.name = name;
}
public void setVersion(String version) {
this.version = version;
}
}
- 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
注意:
-
在
@ConfigurationProperties注釋中有兩個屬性:locations:指定配置文件的所在位置prefix:指定配置文件中鍵名稱的前綴(我這里配置文件中所有鍵名都是以web.開頭)
-
使用
@Component是讓該類能夠在其他地方被依賴使用,即使用@Autowired注釋來創建實例。
創建測試Controller
@RestController
@RequestMapping(value = "config")
public class ConfigController {
@Autowired
private MyWebConfig myWebConfig;
@RequestMapping(value = "index", method = RequestMethod.GET)
public String index() {
return "webName: "+myWebConfig.getName()+", webVersion: "+
myWebConfig.getVersion()+", webAuthor: "+myWebConfig.getAuthor();
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
注意:由於在MyWebConfig類上加了注釋@Component,所以可以直接在這里使用@Autowired來創建其實例對象。
訪問:http://localhost:9090/config/index 時將得到webName: zslin, webVersion: V 1.0, webAuthor: 393156105@qq.com
示例代碼:https://github.com/zsl131/spring-boot-test/tree/master/study02
本文章來自【知識林】
版權聲明:本文為博主原創文章,未經博主允許不得轉載。更多資料上【知識林】:www.zslin.com
