在SpringBoot启动类中用@value获取配置信息为空

最近项目结构比较复杂,在生产环境和测试环境,启动类中加载的动动有差异,每次调试时改来改去,麻烦,还来想想,能否通过spring.profiles.active属性来区分测试环境和生产环境,加个判断不就解决了!

resources目录如下:
在这里插入图片描述

因项目中本来就使用了 onlinne 和 offline的配置,所以spring.profiles.active该属性绝对好使,可是在启动类中用@Value,获取到 active=null,代码如下:

@SpringBootApplication(exclude = {
    
    DataSourceAutoConfiguration.class})
@EnableScheduling
public class RuoYiApplication
{
    
    
	@Value("${spring.profiles.active}")
    private static String active;
    public static void main(String[] args)
    {
    
    
	System.out.println("~~~~~~~~~~~~`" + active);
    SpringApplication.run(RuoYiApplication.class, args);
    }
}

结果日志输出:
在这里插入图片描述
打印了2次,没报错,却获取不到值??
看了看代码,细心的同学输出位置不对,SpringApplication都没启动,注解的东西当然拿不到,果断换一下输出代码顺序,将其移至启动之后执行:

	SpringApplication.run(RuoYiApplication.class, args);
	System.out.println("~~~~~~~~~~~~`" + active);
        

本想这样,应该没问题了,结果日志输入,active 依然为 null。本以为是因为在启动类中获取不到配置信息,后来分析了下此处与前几天总结的Spring 获取配置文件属性的三种方法发现,active前属性有 static修饰,查了下资料,试了下,果断解决了,使用了static修饰的属性,需要通过set方法来赋值。
代码如下:

@SpringBootApplication(exclude = {
    
    DataSourceAutoConfiguration.class})
@EnableScheduling
public class RuoYiApplication
{
    
    
    private static String active;
	@Value("${spring.profiles.active}")
	public void setActive(String value) {
    
    
		active = value;
	}
    public static void main(String[] args)
    {
    
    
        SpringApplication.run(RuoYiApplication.class, args);
        System.out.println("~~~~~~~~~~~~`" + active);
    }
}

看来我对SpringBoot注解的使用,理解还不够,不过通过这个例子,相信大家也应该明白了,SpringApplication.run执行成功后,SpringBoot基础注解应该都能用了。

猜你喜欢

转载自blog.csdn.net/pengain/article/details/114117778