最近项目结构比较复杂,在生产环境和测试环境,启动类中加载的动动有差异,每次调试时改来改去,麻烦,还来想想,能否通过
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基础注解应该都能用了。