注意:配置文件中的字符串不要有下划线 .配置中 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