环境:springboot2.3.9
应用启动后执行相关任务
当程序启动完后需要执行一些操作,可以实现ApplicationRunner 或 CommandLineRunner接口。
示例代码:
@SpringBootApplication
public class SpringBootFunctionsApplication implements ApplicationRunner {
public static void main(String[] args) {
SpringApplication.run(SpringBootFunctionsApplication.class, args);
System.out.println("main method invoke...") ;
}
@Override
public void run(ApplicationArguments args) throws Exception {
System.out.println("应用程序启动完成后通过ApplicationRunner执行相关工作:" + Arrays.toString(args.getSourceArgs())) ;
}
}
执行结果:
Runner对应的run方法会在SpringApplication.run方法之前完成。
程序中访问应用程序启动参数
比如:在定义Bean时需要获取应用程序的启动参数可以通过注入ApplicationArguments实现
示例代码:
@Configuration
public class ArgumentConfig {
@Bean
public Object object(ApplicationArguments args) {
System.out.println(Arrays.toString(args.getSourceArgs())) ;
return new Object() ;
}
}
执行结果:
在配置文件中生成随机值
配置文件:
user:
password: ${random.value}
age: ${random.int(100)}
id: ${random.long}
uuid: ${random.uuid}
Bean属性:
@Component
@ConfigurationProperties(prefix = "user")
public class RandomProperties {
private String password ;
private int age ;
private long id ;
private String uuid ;
}
启动类后输出配置信息:
@SpringBootApplication
public class SpringBootFunctionsApplication implements ApplicationRunner, ApplicationContextAware {
private ApplicationContext ctx ;
public static void main(String[] args) {
SpringApplication.run(SpringBootFunctionsApplication.class, args);
}
@Override
public void run(ApplicationArguments args) throws Exception {
RandomProperties props = this.ctx.getBean(RandomProperties.class) ;
System.out.println(props.getUuid() + "\n" + props.getPassword() + "\n" + props.getId() + "\n" + props.getAge()) ;
}
}
执行结果:
禁用命令行属性
在通过jar运行springboot项目时默认在命令行通过 "--xxx=yyy"设置命令行属性,如下:
java -jar spring-boot-functions-1.0.0.jar --server.port=5555
启动时端口在5555上
如何禁止命令行属性?修改启动类SpringApplication#
setAddCommandLineProperties方法
public static void main(String[] args) {
SpringApplication app = new SpringApplication(SpringBootFunctionsApplication.class) ;
app.setAddCommandLineProperties(false) ;
app.run(args) ;
System.out.println("main method invoke...") ;
}
执行结果:
已经不再生效了。
应用程序加载配置文件的地方及优先级
1、 当前目录的/config子目录
2、 当前目录
3、 类路径路径下的/config目录
4、 类路径的根目录classpath: /
从上到下 :上面的会覆盖下面的(优先级由高到低)
默认加载的都是applicaton.properties或yml文件,也可以在启动时指定配置文件名
java -jar xxx.jar --spring.config.name=yyyy
也可以通过如下启动参数指定文件位置
java -jar xxx.jar --spring.config.location=classpath:/default.properties,classpath:/override.properties
YAML 配置文件缺陷
无法使用@PropertySource注解的方式来加载配置文件,只能使用properties文件。
@Configuration
@PropertySources({@PropertySource("classpath:config.yml")})
public class ArgumentConfig {
}
这里是不会生效的,不支持yml文件,只能是properties文件。
@EnableConfigurationProperties的使用
当一个配置属性类只添加了@ConfigurationProperties(prefix = "user")注解,而没有使用@Component注解,那么在spring容器中是不会生成对应属性的Bean。
在任何使用了@Configuration注解的类上添加@
EnableConfigurationProperties(xx)注解,那么对应有@ConfigurationProperties注解的类就会被Environment属性配置。
@Configuration
@EnableConfigurationProperties(RandomProperties.class)
public class ArgumentConfig {
}
@ConfigurationProperties(prefix = "user")
public class RandomProperties {
private String password ;
private int age ;
private long id ;
private String uuid ;
}
给个关注呗谢谢啊