此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring Shell 3.3.3! |
异常解决
未处理的异常将冒泡到 shell 中,然后最终
由 的某个实例处理。实施链
可用于解决异常,并为您提供返回消息的灵活性
与包装在 . 可能包含消息和/或退出代码。ResultHandlerService
ResultHandler
ExceptionResolver
CommandHandlingResult
CommandHandlingResult
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。
@Bean
CustomExceptionResolver customExceptionResolver() {
return new CustomExceptionResolver();
}
或者 defined per 如果它仅适用于特定命令本身。CommandRegistration
CommandRegistration.builder()
.withErrorHandling()
.resolver(new CustomExceptionResolver())
.and()
.build();
使用命令定义的解析程序在全局解析程序之前处理。 |
使用你自己的异常类型,它也可以是 boot 的 if
您希望在此处定义退出代码。ExitCodeGenerator
static class CustomException extends RuntimeException implements ExitCodeGenerator {
@Override
public int getExitCode() {
return 0;
}
}
一些内置的 bean 被注册为处理常见的
命令解析引发的异常。这些 Cookie 使用 中定义的 order presedence 进行注册。
由于这些 bean 是按给定的顺序使用的,因此可以像在任何其他 Spring 应用程序中一样使用 Comments 或 interface from。这
如果您需要控制自己的 bean 才能使用
在 defaults 之前或之后。CommandExceptionResolver
CommandExceptionResolver.DEFAULT_PRECEDENCE
@Order
Ordered