• 转载 springboot 配置读取


    前言:了解过spring-Boot这个技术的,应该知道Spring-Boot的核心配置文件application.properties,当然也可以通过注解自定义配置文件**.properties的信息。

    一.读取核心配置文件信息application.properties的内容

         核心配置文件是指在resources根目录下的application.properties或application.yml配置文件,读取这两个配置文件的方法有两种,都比较简单。

    (1)核心配置文件application.properties内容如下:

    1. test.msg=Hello World SpringBoot  

    (1)方式一:使用@Value方式(常用)

    1. package Solin.controller;  
    2.   
    3. import org.springframework.beans.factory.annotation.Value;  
    4. import org.springframework.web.bind.annotation.RequestMapping;  
    5. import org.springframework.web.bind.annotation.RestController;  
    6.   
    7. @RestController  
    8. public class WebController {  
    9.     @Value("${test.msg}")  
    10.     private String msg;  
    11.       
    12.     @RequestMapping("/index1")   
    13.     public String index1(){  
    14.         return "方式一:"+msg;  
    15.     }  
    16. }

    注意:在@Value的${}中包含的是核心配置文件中的键名。在Controller类上加@RestController表示将此类中的所有视图都以JSON方式显示,类似于在视图方法上加@ResponseBody。
    访问:http://localhost:8088/index1时得到:"方式一:Hello World SpringBoot"

    (2)方式二:使用Environment方式


    1. package Solin.controller;  
    2.   
    3. import org.springframework.beans.factory.annotation.Autowired;  
    4. import org.springframework.beans.factory.annotation.Value;  
    5. import org.springframework.core.env.Environment;  
    6. import org.springframework.web.bind.annotation.RequestMapping;  
    7. import org.springframework.web.bind.annotation.RestController;  
    8.   
    9. @RestController  
    10. public class WebController {  
    11.     @Autowired  
    12.     private Environment env;  
    13.       
    14.     @RequestMapping("/index2")   
    15.     public String index2(){  
    16.         return "方式二:"+env.getProperty("test.msg");  
    17.     }  
    18. }  

    注意:这种方式是依赖注入Evnironment来完成,在创建的成员变量private Environment env上加上@Autowired注解即可完成依赖注入,然后使用env.getProperty("键名")即可读取出对应的值。

    访问:http://localhost:8088/index2时得到:"方式二:Hello World SpringBoot"

    (2)核心配置文件application-dev.yml内容如下:

     
    1. # --**银行配置文件路径 start
      czb:
        configPath: /usr/local/czbConfig/config.properties
      # --浙商银行相关配置文件路径 end

    application*.yml核心配置文件,也是用上面两种方式读取其内容。例如:如下图使用方式一来读取:

    二.读取自定义配置文件信息,例如:author.properties

    为了不破坏核心文件的原生态,但又需要有自定义的配置信息存在,一般情况下会选择自定义配置文件来放这些自定义信息,这里在resources目录下创建配置文件authorA.properties

    resources/author/authorA.properties内容如下:

     
    1. auth.name=Solin  
    2. auth.age=22  

    创建管理配置的实体类:


    1. package Solin.controller;  
    2.   
    3. import org.springframework.boot.context.properties.ConfigurationProperties;  
    4. import org.springframework.context.annotation.Configuration;  
    5. import org.springframework.stereotype.Component;  
    6.     
    7. //加上注释@Component,可以直接其他地方使用@Autowired来创建其实例对象
    8. @Component  
    9. //springboot1.5之前的版本这么用,1.5版本之后取消了locations属性,替代方案看最下面。
    10. @ConfigurationProperties(prefix = "auth",locations = "classpath:/author/authorA.properties") 
    11. //在启动类上增加@EnableConfigurationProperties注解,激活自定义的配置类(重要)
    12. public class MyWebConfig{  
    13.     private String name;  
    14.     private int age;  
    15.     public String getName() {  
    16.         return name;  
    17.     }  
    18.     public void setName(String name) {  
    19.         this.name = name;  
    20.     }  
    21.     public int getAge() {  
    22.         return age;  
    23.     }  
    24.     public void setAge(int age) {  
    25.         this.age = age;  
    26.     }  
    27. }  

    注意:
        在@ConfigurationProperties注释中有两个属性:
                  locations:指定配置文件的所在位置
                  prefix:指定配置文件中键名称的前缀(我这里配置文件中所有键名都是以auth.开头)
        使用@Component是让该类能够在其他地方被依赖使用,即使用@Autowired注释来创建实例。

    创建测试Controller

     
    1. package Solin.controller;  
    2.   
    3. import org.springframework.beans.factory.annotation.Autowired;  
    4. import org.springframework.stereotype.Controller;  
    5. import org.springframework.web.bind.annotation.RequestMapping;  
    6. import org.springframework.web.bind.annotation.ResponseBody;  
    7.   
    8. @Controller    
    9. public class ConfigController {  
    10.     @Autowired  
    11.     private MyWebConfig conf;  
    12.       
    13.     @RequestMapping("/test")   
    14.     public @ResponseBody String test() {  
    15.         return "Name:"+conf.getName()+"---"+"Age:"+conf.getAge();   
    16.     }  
    17. }  

    注意:由于在Conf类上加了注释@Component,所以可以直接在这里使用@Autowired来创建其实例对象。

    访问:http://localhost:8088/test时得到:"Name:Solin---Age:22"


    备注:spring boot1.5以上版本@ConfigurationProperties取消locations注解后的替代方案,只是下面注解变了,别的都一样。

    创建管理配置的实体类:


    1. package Solin.controller;  
    2.   
    3. import org.springframework.boot.context.properties.ConfigurationProperties;  
    4. import org.springframework.context.annotation.Configuration;  
    5. import org.springframework.stereotype.Component;  
    6.     
    7. @Component  
    8. @ConfigurationProperties(prefix ="auth") 
    9. @PropertySource("classpath:/author/authorA.properties")//@PropertySource来指定自定义的资源目录
    10. //在启动类上取消掉@EnableConfigurationProperties注解,springboot1.5版本之后不需要@EnableConfigurationProperties注解了。
    11. public class MyWebConfig{  
    12.     private String name;  
    13.     private int age;  
    14.     public String getName() {  
    15.         return name;  
    16.     }  
    17.     public void setName(String name) {  
    18.         this.name = name;  
    19.     }  
    20.     public int getAge() {  
    21.         return age;  
    22.     }  
    23.     public void setAge(int age) {  
    24.         this.age = age;  
    25.     }  
    26. }  
     
     
    1. test.msg=Hello World SpringBoot  
  • 相关阅读:
    二进制包安装MySQL数据库
    Nginx 访问日志轮询切割
    安装Nginx服务
    生产环境常见的HTTP状态码列表
    SSH批量部署服务
    MYSQL数据库的优化
    inotify+rsync实现实时同步部署
    rsync同步架构
    Linux shell脚本编程(三)
    Linux shell脚本编程(二)
  • 原文地址:https://www.cnblogs.com/welkinwalker/p/9222284.html
Copyright © 2020-2023  润新知