一,配置文件值注入

(1)@ConfigurationProperties获取值

(2)@Value获取值

(3)@PropertySource:加载指定的配置文件;

(4)@ImportResource:导入Spring的配置文件,让配置文件里面的内容生效;(添加在Application类里面

(5)1、配置类@Configuration------>Spring配置文件 2、使用@Bean给容器中添加组

如果说,我们只是在某个业务逻辑中需要获取一下配置文件中的某项值,使用@Value;
如果说,我们专门编写了一个javaBean来和配置文件进行映射,我们就直接使用@ConfigurationProperties;

@PropertySource(value = {"classpath:application-proudues.yml"})
@Component
@ConfigurationProperties(prefix = "person")
public class Person {
    //name必须是邮箱格式
//    @Email
   // @Value("${person.name}")
    private  String name;
    //@value支持但是@ConfigurationProperties 不支持
    //@Value("#{15*2}")
    private  int age;
    // @Value("1995/02/28")
    private Date brithday;
    private Dog dog;
    private List<String> list;
    private Map<String,String> map;

springBoot续写

二,配置文件注入值数据校验

springBoot续写

三,配置文件占位符

springBoot续写

springBoot续写

四,**指定的profile文件

springBoot续写

加载的顺序

springBoot续写

项目打包好以后,我们可以使用命令行参数的形式,启动项目的时候来指定配置文件的新位置;指定配置文件和默
认加载的这些配置文件共同起作用形成互补配置;

java -jar spring-boot-02-config-02-0.0.1-SNAPSHOT.jar --spring.config.location=G:/application.properties

五,外部配置加载顺序

SpringBoot也可以从以下位置加载配置; 优先级从高到低;高优先级的配置覆盖低优先级的配置,所有的配置会
形成互补配置

1.命令行参数
所有的配置都可以在命令行上进行指定
java -jar spring-boot-02-config-02-0.0.1-SNAPSHOT.jar --server.port=8087 --server.context-path=/abc
多个配置用空格分开; --配置项=值
2.来自java:comp/env的JNDI属性
3.Java系统属性(System.getProperties())
4.操作系统环境变量
5.RandomValuePropertySource配置的random.*属性值
由jar包外向jar包内进行寻找;
优先加载带profile
6.jar包外部的application-{profile}.properties或application.yml(带spring.profile)配置文件
7.jar包内部的application-{profile}.properties或application.yml(带spring.profile)配置文件
再来加载不带profile
8.jar包外部的application.properties或application.yml(不带spring.profile)配置文件
9.jar包内部的application.properties或application.yml(不带spring.profile)配置文件
[email protected]注解类上的@PropertySource
11.通过SpringApplication.setDefaultProperties指定的默认属性



相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-06-30
  • 2021-07-18
  • 2021-12-30
  • 2021-07-09
  • 2021-09-01
  • 2022-01-10
猜你喜欢
  • 2021-09-23
  • 2021-08-30
  • 2021-11-24
  • 2021-12-30
  • 2021-12-19
  • 2021-09-27
  • 2022-12-23
相关资源
相似解决方案