在使用spring boot 構(gòu)建應(yīng)用啟動(dòng)時(shí),我們?cè)诠ぷ髦卸际峭ㄟ^命令行來啟動(dòng)應(yīng)用,有時(shí)候會(huì)需要一些特定的參數(shù)以在應(yīng)用啟動(dòng)時(shí),做一些初始化的操作。
spring boot 提供了 commandlinerunner 和 applicationrunner 這兩個(gè)接口供用戶使用。
1. commandlinerunner
1.1 聲明:
1
2
3
4
5
6
7
8
9
10
11
|
@functionalinterface public interface commandlinerunner { /** * callback used to run the bean. * @param args incoming main method arguments * @throws exception on error */ void run(string... args) throws exception; } |
1.2 使用:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package com.example.consoleapplication; import org.springframework.boot.commandlinerunner; import org.springframework.stereotype.component; @component public class testrunner implements commandlinerunner { @override public void run(string... args) { // do something... for (string arg: args){ system.out.println(arg); } system.out.print( "test command runner" ); } } |
1.3 運(yùn)行結(jié)果
運(yùn)行: java -jar build/libs/consoleapplication-0.0.1-snapshot.jar -sdfsaf sdfas,
結(jié)果如下:
2019-03-16 17:31:56.544 info 18679 --- [ main] c.e.consoleapplication.demoapplication : no active profile set, falling back to default profiles: default
2019-03-16 17:31:57.195 info 18679 --- [ main] c.e.consoleapplication.demoapplication : started demoapplication in 16.172 seconds (jvm running for 16.65)
-sdfsaf
sdfas
test command runner%
2. applicationrunner
2.1 聲明
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/** * interface used to indicate that a bean should <em>run</em> when it is contained within * a {@link springapplication}. multiple {@link applicationrunner} beans can be defined * within the same application context and can be ordered using the {@link ordered} * interface or {@link order @order} annotation. * * @author phillip webb * @since 1.3.0 * @see commandlinerunner */ @functionalinterface public interface applicationrunner { /** * callback used to run the bean. * @param args incoming application arguments * @throws exception on error */ void run(applicationarguments args) throws exception; } |
2.2 使用
applicationrunner 和 commandlinerunner 的使用是有差別的:
- commandlinerunner 的使用,只是把參數(shù)根據(jù)空格分割。
-
applicationrunner 會(huì)根據(jù) 是否匹配 --key=value 來解析參數(shù),
- 能匹配,則為 optional 參數(shù), 可用getoptionvalues獲取參數(shù)值。
- 不匹配則是 non optional 參數(shù)。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
package com.example.consoleapplication; import org.springframework.boot.applicationrunner; import org.springframework.stereotype.component; import org.springframework.boot.applicationarguments; @component public class testapplicationrunner implements applicationrunner { @override public void run(applicationarguments args) throws exception { // do something... system.out.println( "option arg names" + args.getoptionnames()); system.out.println( "non option+" + args.getnonoptionargs()); } } |
2.3 運(yùn)行結(jié)果
運(yùn)行命令 java -jar build/libs/consoleapplication-0.0.1-snapshot.jar -non1 non2 --option=1
, 結(jié)果為:
2019-03-16 18:08:08.528 info 19778 --- [ main] c.e.consoleapplication.demoapplication : no active profile set, falling back to default profiles: default
2019-03-16 18:08:09.166 info 19778 --- [ main] c.e.consoleapplication.demoapplication : started demoapplication in 16.059 seconds (jvm running for 16.56)
test
option arg names[option]
non option+[-non1, non2]-non1
non2
--option=1
test%
可以看到, optional 參數(shù)名有 option, non optional 參數(shù)有 -non1 和 non2
3. 小結(jié)
commandlinerunner 和 applicationrunner 都能實(shí)現(xiàn)命令行應(yīng)用啟動(dòng)時(shí)根據(jù)參數(shù)獲取我們需要的值,做特殊的邏輯。但兩者有所不同,推薦使用 applicationrunner 的 optional 參數(shù), 方便擴(kuò)展。
4. 參考文檔
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://segmentfault.com/a/1190000018530137