一、讀取核心配置文件
核心配置文件是指在resources根目錄下的application.properties或application.yml配置文件,讀取這兩個配置文件的方法有兩種,都比較簡單。
核心配置文件application.properties內容如下:
server.port=9090 test.msg=Hello World Springboot!
1、使用@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; } }
注意:在@Value的${}中包含的是核心配置文件中的鍵名。在Controller類上加@RestController表示將此類中的所有視圖都以JSON方式顯示,類似於在視圖方法上加@ResponseBody。
訪問:http://localhost:9090/index 時將得到The Way 1 : Hello World Springboot!
2、使用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"); } }
注意:這種方式是依賴注入Evnironment來完成,在創建的成員變量private Environment env上加上@Autowired注解即可完成依賴注入,然后使用env.getProperty("鍵名")即可讀取出對應的值。
二、讀取自定義配置文件
為了不破壞核心文件的原生態,但又需要有自定義的配置信息存在,一般情況下會選擇自定義配置文件來放這些自定義信息,這里在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個注解:@ConfigurationProperties
@Component,把該類變成spring的一個組件
@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)在@ConfigurationProperties注釋中有兩個屬性:
locations:指定配置文件的所在位置
prefix:指定配置文件中鍵名稱的前綴(我這里配置文件中所有鍵名都是以web.開頭)
(2)使用@Component是讓該類能夠在其他地方被依賴使用,即使用@Autowired注釋來創建實例。
2、創建測試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(); } }
注意:由於在MyWebConfig類上加了注釋@Component,所以可以直接在這里使用@Autowired來創建其實例對象。
訪問:http://localhost:9090/config/index 時將得到webName: zslin, webVersion: V 1.0, webAuthor: 393156105@qq.com
