SpringBoot2.x基础篇:应用程序在启动时访问启动项参数
2020/3/4 17:01:21
本文主要是介绍SpringBoot2.x基础篇:应用程序在启动时访问启动项参数,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
知识改变命运,撸码使我快乐,2020继续游走在开源界
点赞再看,养成习惯
给我来个Star吧,点击了解下基于SpringBoot的组件化接口服务落地解决方案
SpringBoot
应用程序在启动时,我们可以传递自定义的参数来进行动态控制逻辑,比如我们使用--debug
启动参数时就会使用debug
启动应用程序,在控制台打印一些调试日志信息。
推荐阅读
什么是启动项参数?
启动项参数的格式一般是--
开头的,如:java -jar service.jar --debug --skip
,启动时我们就可以获取[debug,skip]
两个启动项参数。
SpringBoot 内部提供了一个接口org.springframework.boot.ApplicationArguments
来接收应用程序在启动时所传递的选项参数(Option Args)
,源码如下所示:
public interface ApplicationArguments { /** * 返回未处理的原始参数列表 * @return the arguments */ String[] getSourceArgs(); /** * 返回所有选项参数的名称 * For example, if the arguments were * "--foo=bar --debug" would return the values {@code ["foo", "debug"]}. * @return the option names or an empty set */ Set<String> getOptionNames(); /** * 根据选项参数名称判断是否在启动时传递 * option with the given name. * @param name the name to check * @return {@code true} if the arguments contain an option with the given name */ boolean containsOption(String name); /** * 返回与具有给定名称的arguments选项关联的值的集合。 * <ul> * <li>if the option is present and has no argument (e.g.: "--foo"), return an empty * collection ({@code []})</li> * <li>if the option is present and has a single value (e.g. "--foo=bar"), return a * collection having one element ({@code ["bar"]})</li> * <li>if the option is present and has multiple values (e.g. "--foo=bar --foo=baz"), * return a collection having elements for each value ({@code ["bar", "baz"]})</li> * <li>if the option is not present, return {@code null}</li> * </ul> * @param name the name of the option * @return a list of option values for the given name */ List<String> getOptionValues(String name); /** * 返回分析的非选项参数的集合。 * @return the non-option arguments or an empty list */ List<String> getNonOptionArgs(); }复制代码
该接口有一个默认的实现DefaultApplicationArguments
,它实现了ApplicationArguments
接口的全部定义方法。
DefaultApplicationArguments
类在org.springframework.boot.SpringApplication#run(java.lang.String...)
方法内通过new
进行实例化,该对象实例主要用于启动时的相关配置。
而在启动过程中的org.springframework.boot.SpringApplication#prepareContext
方法内通过ConfigurableListableBeanFactory
进行注册到IOC
容器,并且把springApplicationArguments
作为唯一名称。
获取启动项参数
上面我们说道,在应用启动时会将ApplicationArguments
接口的实现类实例注册到IOC
容器,所以我们可以使用注入ApplicationArguments
接口的形式来获取启动项参数,如下所示:
/** * 加载启动项参数 * * @author 恒宇少年 */ @Component public class LoadArguments { /** * 构造函数注入{@link ApplicationArguments} * * @param applicationArguments */ @Autowired public LoadArguments(ApplicationArguments applicationArguments) { // 判断是否存在名为skip的启动项参数 boolean isHaveSkip = applicationArguments.containsOption("skip"); System.out.println("skip:" + isHaveSkip); // 遍历输出全部的非启动项参数 List<String> arguments = applicationArguments.getNonOptionArgs(); for (int i = 0; i < arguments.size(); i++) { System.out.println("非启动项参数:" + arguments.get(i)); } } }复制代码
我们把项目通过mvn package
命令进行打包后,使用如下命令启动:
java -jar spring-boot-basic-accessing-application-arguments-0.0.1-SNAPSHOT.jar --skip noway复制代码
当我们启动后控制台会输出如下内容:
... skip:true 非启动项参数:noway ...复制代码
其中--skip
为启动项参数,而后面携带的noway
其实是不属于skip
启动参数,如果我们使用--skip=noway
作为启动参数时,调用ApplicationArguments#getOptionValues("skip")
方法获取到的值则是noway
。
ApplicationRunner
除了通过注入ApplicationArguments
的方式获取启动参数外,通过实现ApplicationRunner
接口也可以获取ApplicationArguments
对象实例,使用方法如下所示:
/** * {@link ApplicationRunner} 实现类 * * @author 恒宇少年 */ @Component public class ApplicationRunnerSupport implements ApplicationRunner { @Override public void run(ApplicationArguments args) throws Exception { boolean isHaveSkip = args.containsOption("skip"); System.out.println("skip:" + isHaveSkip); System.out.println(args.getOptionValues("skip")); } }复制代码
注意事项:实现
ApplicationRunner
接口的类需要通过@Component
标注,通过注解方式注册到IOC
容器。
敲黑板,划重点
我们可以通过注入
、ApplicationRunner
这两种方法来获取ApplicationArguments
对象,那你知道这两种方法的执行先后顺序吗?带着这个疑问可以动手实验下。
代码示例
如果您喜欢本篇文章请为源码仓库点个Star
,谢谢!!!本篇文章示例源码可以通过以下途径获取,目录为spring-boot-basic-accessing-application-arguments
:
- Gitee:gitee.com/hengboy/spr…
作者个人 博客
使用开源框架 ApiBoot 助你成为Api接口服务架构师
这篇关于SpringBoot2.x基础篇:应用程序在启动时访问启动项参数的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-26大厂数据结构与算法教程:入门级详解
- 2024-12-26大厂算法与数据结构教程:新手入门指南
- 2024-12-26Python编程入门指南
- 2024-12-26数据结构高级教程:新手入门及初级提升指南
- 2024-12-26并查集入门教程:从零开始学会并查集
- 2024-12-26大厂数据结构与算法入门指南
- 2024-12-26大厂算法与数据结构入门教程
- 2024-12-26二叉树入门教程:轻松掌握基础概念与操作
- 2024-12-26初学者指南:轻松掌握链表
- 2024-12-26平衡树入门教程:轻松理解与应用