色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Spring Shell應(yīng)用程序開(kāi)發(fā)流程解析

瀏覽:42日期:2023-08-06 17:54:43

向shell提供命令非常簡(jiǎn)單,需要學(xué)習(xí)的注解很少。該命令的實(shí)現(xiàn)風(fēng)格與使用依賴(lài)注入的應(yīng)用程序的開(kāi)發(fā)類(lèi)相同,您可以利用Spring容器的所有特性來(lái)實(shí)現(xiàn)您的命令類(lèi)。

spring-shell官網(wǎng)地址:https://projects.spring.io/spring-shell/

標(biāo)記接口

創(chuàng)建命令的第一步是實(shí)現(xiàn)標(biāo)記接口CommandMarker,并使用Spring的@Component注解對(duì)類(lèi)進(jìn)行注解(注意一個(gè)JIRA問(wèn)題:提供@CliCommand元注解避免使用標(biāo)記接口)。使用helloworld示例應(yīng)用程序中的代碼為例,HelloWorldCommands類(lèi)的代碼如下所示:

@Componentpublic class HelloWorldCommands implements CommandMarker { // use any Spring annotations for Dependency Injection or other Spring interfaces // as required. // methods with @Cli annotations go here}

日志

目前,日志記錄是使用JDK日志記錄的。由于控制臺(tái)、JLine和Ansi處理的復(fù)雜性,一般都建議將消息作為返回值的方式顯示在shell窗口。但是,當(dāng)需要進(jìn)行日志記錄時(shí),典型的JDK logger聲明就足夠了。

@Componentpublic class HelloWorldCommands implements CommandMarker { protected final Logger LOG = Logger.getLogger(getClass().getName()); // methods with @Cli annotations go here}

注意:一般開(kāi)發(fā)人員的職責(zé)是為第三方庫(kù)處理日志,應(yīng)當(dāng)要減少日志級(jí)別,這樣控制臺(tái)或者shell窗口就不會(huì)受到日志消息的影響。

CLI注解

在方法和方法參數(shù)上使用了三個(gè)注釋?zhuān)@些注釋定義了與shell交互的主要契約,分別是:

CliAvailabilityIndicator - 放在一個(gè)方法前返回一個(gè)布爾值,表示在shell中是否可以執(zhí)行一個(gè)特定的命令。這個(gè)決定通常基于之前執(zhí)行的命令的歷史。它可以防止在滿(mǎn)足某些先決條件時(shí)出現(xiàn)外部命令,例如執(zhí)行’configuration’命令。 CliCommand - 放置在向shell提供命令的方法上。它的值提供了一個(gè)或多個(gè)字符串,這些字符串作為特定命令名的開(kāi)始。在整個(gè)應(yīng)用程序中,包括所有的插件中這些必須是唯一的。 CliOption - 放置在命令方法的參數(shù)中,允許它默認(rèn)值聲明參數(shù)值為必填的或可選的。

下面是在命令類(lèi)中使用這些注解的簡(jiǎn)單用法

@Componentpublic class HelloWorldCommands implements CommandMarker { @CliAvailabilityIndicator({'hw simple'}) public boolean isCommandAvailable() { return true; } @CliCommand(value = 'hw simple', help = 'Print a simple hello world message') public String simple( @CliOption(key = { 'message' }, mandatory = true, help = 'The hello world message') final String message, @CliOption(key = { 'location' }, mandatory = false,help = 'Where you are saying hello', specifiedDefaultValue='At work') final String location) { return 'Message = [' + message + '] Location = [' + location + ']'; }}

注解@CliAvailabilityIndicator方法返回true,這是這個(gè)類(lèi)中暴露給shell調(diào)用的唯一的命令。如果類(lèi)中有更多的命令,則將它們作為逗號(hào)分隔值列出。

@CliCommand注解是創(chuàng)建shell命令’hw simple’。幫助消息是如果您使用幫助命令’help’將會(huì)打印什么內(nèi)容。這里定義方法名是“simple”,但它可以是任何自定義的名稱(chēng)。

@CliOption注解在每個(gè)命令的參數(shù)。您需要決定哪些參數(shù)是必需的,哪些是可選的,如果它們是可選的,則有一個(gè)默認(rèn)值。在本例中,該命令有兩個(gè)參數(shù):消息’message’和位置’location’。需要使用消息選項(xiàng),并提供一個(gè)幫助消息,以便在為該命令完成任務(wù)時(shí)為用戶(hù)提供指導(dǎo)。

“simple”方法的實(shí)現(xiàn)很簡(jiǎn)單,只是一個(gè)日志語(yǔ)句,但這是通常調(diào)用的其他對(duì)象,這些對(duì)象是通過(guò)Spring注入到類(lèi)中的,然后可以實(shí)現(xiàn)復(fù)雜的功能。

本例中的方法參數(shù)類(lèi)型是String,它不會(huì)出現(xiàn)類(lèi)型轉(zhuǎn)換的任何問(wèn)題。您可以指定任何的對(duì)象類(lèi)型以及基本數(shù)據(jù)類(lèi)型,如int, float等。對(duì)所有類(lèi)型以外由默認(rèn)shell(基本數(shù)據(jù)類(lèi)型, Date, File)需要在您的插件中與容器的轉(zhuǎn)換器接口org.springframework.shell.core.Converter 注冊(cè)它的轉(zhuǎn)換。

注意,方法返回參數(shù)可以是非void,在我們的示例中,它是我們想要顯示的實(shí)際消息。返回非void類(lèi)型時(shí),shell將顯示為它的toString()字符。

測(cè)試shell命令

執(zhí)行測(cè)試的shell命令,您可以實(shí)例化shell在一個(gè)測(cè)試用例中執(zhí)行命令,然后在返回值CommandResult執(zhí)行斷言。一個(gè)簡(jiǎn)單的基類(lèi)設(shè)置如下所示:

public abstract class AbstractShellIntegrationTest { private static JLineShellComponent shell; @BeforeClass public static void startUp() throws InterruptedException { Bootstrap bootstrap = new Bootstrap(); shell = bootstrap.getJLineShellComponent(); } @AfterClass public static void shutdown() { shell.stop(); } public static JLineShellComponent getShell() { return shell; }}

這里有一個(gè)測(cè)試日期命令的例子:

public class BuiltInCommandTests extends AbstractShellIntegrationTest { @Test public void dateTest() throws ParseException { //Execute command CommandResult cr = getShell().executeCommand('date'); //Get result DateFormat df = DateFormat.getDateTimeInstance(DateFormat.FULL, DateFormat.FULL,Locale.US); Date result = df.parse(cr.getResult().toString()); //Make assertions - DateMaters is an external dependency not shown here. Date now = new Date(); MatcherAssert.assertThat(now, DateMatchers.within(5, TimeUnit.SECONDS, result)); }}

CommandResult的getResult方法返回的 java.lang.Class將匹配與@CliCommand注解方法的返回值。您應(yīng)該向適當(dāng)?shù)念?lèi)型轉(zhuǎn)換,以幫助執(zhí)行您的斷言。

構(gòu)建和運(yùn)行shell

在我們看來(lái),構(gòu)建和執(zhí)行shell最簡(jiǎn)單的方法是剪切和粘貼腳本。這將使來(lái)自于分級(jí)的應(yīng)用程序插件創(chuàng)建一個(gè)bin目錄,該目錄帶有用于windows和Unix的啟動(dòng)腳本,并將所有依賴(lài)jar放在lib目錄中。Maven有一個(gè)類(lèi)似的插件——AppAssembler插件。

shell的主類(lèi)是org.springframework.shell.Bootstrap的。只要您在類(lèi)路徑上放置其他的插件,或者是獨(dú)立開(kāi)發(fā)的,引導(dǎo)類(lèi)就會(huì)將它們合并到shell中。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 国产精品黄网站 | 免费看片aⅴ免费大片 | 久久厕所精品国产精品亚洲 | 免费刺激视频 | 久久久久欧美国产精品 | 久草视频免费播放 | 成人午夜久久 | 国产成人a福利在线观看 | 99精品一区二区三区 | 中国成人免费视频 | tom影院亚洲国产 | a黄网站| 性盈盈影院影院67194 | 夜夜躁狠狠躁日日躁2021 | 久久久久久久久一级毛片 | 九草在线视频 | www射射一区 | 亚洲精品综合一区二区三区 | 日韩精品免费一区二区 | 综合色久| 日韩精品亚洲一级在线观看 | 美女亚洲视频 | 日韩三级黄色片 | 亚洲国产精品久久人人爱 | 日韩精品免费看 | 一级特黄aa大片欧美 | 波多野结衣中文在线 | 97精品国产综合久久久久久欧美 | 在线观看久草视频 | a级片免费在线播放 | 久久久久久久免费视频 | 日本美女高清在线观看免费 | a在线观看欧美在线观看 | 国产精品久久永久免费 | 日本xxxxx黄区免费看动漫 | 亚洲在线观看免费 | 三级全黄视频 | 成年人性网站 | 91精品国产91久久 | 久久综合精品不卡一区二区 | 兔子先生节目在线观看免费 |