|
对于最新的稳定版本,请使用 Spring Shell 3.4.0! |
@ExceptionResolver
@ShellComponent类可以具有@ExceptionResolver处理 Component 异常的方法
方法。这些用于带 Comments 的方法。
该异常可能与正在传播的顶级异常匹配(例如,直接的 IOException 被抛出)或针对包装器异常中的嵌套原因(例如,包装的 IOException 在 IllegalStateException 中)。这可以在任意原因级别匹配。
对于匹配的异常类型,最好将目标异常声明为方法参数,如 前面的示例显示了。当多个异常方法匹配时,根异常匹配为 通常优先于 Cause 异常匹配。更具体地说,ExceptionDepthComparator 用于根据异常从引发的异常类型中对异常的深度对异常进行排序。
或者,注解声明可以缩小要匹配的异常类型,因为 以下示例显示:
@ExceptionResolver({ RuntimeException.class })
CommandHandlingResult errorHandler(Exception e) {
// Exception would be type of RuntimeException,
// optionally do something with it
return CommandHandlingResult.of("Hi, handled exception\n", 42);
}
@ExceptionResolver
CommandHandlingResult errorHandler(RuntimeException e) {
return CommandHandlingResult.of("Hi, handled custom exception\n", 42);
}
@ExceptionResolver也可以返回String用作 console 的输出。您可以
用@ExitCode注解来定义返回代码。
@ExceptionResolver
@ExitCode(code = 5)
String errorHandler(Exception e) {
return "Hi, handled exception";
}
@ExceptionResolver跟voidreturn 类型会自动作为 Handled Exception 处理。
然后,您还可以定义@ExitCode并使用Terminal如果你需要写点什么
进入控制台。
@ExceptionResolver
@ExitCode(code = 5)
void errorHandler(Exception e, Terminal terminal) {
PrintWriter writer = terminal.writer();
String msg = "Hi, handled exception " + e.toString();
writer.println(msg);
writer.flush();
}
方法参数
@ExceptionResolver方法支持以下参数:
| Method 参数 | 描述 |
|---|---|
异常类型 |
用于访问引发的异常。这是任何类型的 |
终端 |
对于底层 |
返回值
@ExceptionResolver方法支持以下返回值:
| 返回值 | 描述 |
|---|---|
字符串 |
用于返回到 shell 的纯文本。在本例中,使用退出代码 1。 |
CommandHandlingResult |
平原 |
无效 |
具有 void 返回类型的方法被视为已完全处理异常。通常
您可以定义 |