此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring Shell 3.4.0spring-doc.cadn.net.cn

异常解决

未处理的异常将冒泡到 shell 的ResultHandlerService然后最终 由ResultHandler.链ExceptionResolver实现 可用于解决异常,并为您提供了返回消息的灵活性 与包装在CommandHandlingResult.CommandHandlingResult可能包含消息和/或退出代码spring-doc.cadn.net.cn

static class CustomExceptionResolver implements CommandExceptionResolver {

	@Override
	public CommandHandlingResult resolve(Exception e) {
		if (e instanceof CustomException) {
			return CommandHandlingResult.of("Hi, handled exception\n", 42);
		}
		return null;
	}
}

CommandExceptionResolver实现可以全局定义为 bean:spring-doc.cadn.net.cn

@Bean
CustomExceptionResolver customExceptionResolver() {
	return new CustomExceptionResolver();
}

或定义CommandRegistration如果它仅适用于特定命令:spring-doc.cadn.net.cn

CommandRegistration.builder()
	.withErrorHandling()
		.resolver(new CustomExceptionResolver())
		.and()
	.build();
使用命令定义的解析程序在全局解析程序之前处理。

您可以使用自己的异常类型,这些类型也可以是 Spring Boot 的ExitCodeGenerator如果你想在那里定义退出代码:spring-doc.cadn.net.cn

static class CustomException extends RuntimeException implements ExitCodeGenerator {

	@Override
	public int getExitCode() {
		return 0;
	}
}

一些内置CommandExceptionResolverbean 注册为处理常见的 命令解析引发的异常。这些注册具有 中定义的顺序优先级CommandExceptionResolver.DEFAULT_PRECEDENCE. 由于这些 bean 是按给定的顺序使用的,因此@Orderannotation 或Orderedinterface 可以像在任何其他 Spring 应用程序中一样使用。这 如果您需要控制自己的 bean 才能使用 在 default 之前或之后。spring-doc.cadn.net.cn