spring学习之restTemplate的异常处理器

异常处理器功能
ResponseErrorHandler异常处理器接口
DefaultResponseErrorHandlerrestTemplate默认的异常处理器,处理客户端和服务端异常
ExtractingResponseErrorHandler根据HttpMessageConverter对象转换器 将HTTP错误响应转换RestClientException 需要指定ResponseErrorHandler
NoOpResponseErrorHandler对异常不进行处理

ResponseErrorHandler

ResponseErrorHandler是restTemplate的异常接口
restTemplate中所有的异常处理器都是实现的它

public interface ResponseErrorHandler {

	/**
	 * 判断请求是否异常
	 * 返回false表示不管response的status是多少都返回没有错
	 * 这里可以自己定义那些status code你认为是可以抛Error
	 * 当然也可以根据response的body来判断
	 */
	boolean hasError(ClientHttpResponse response) throws IOException;

	/**
	 * 这里面可以实现你自己遇到了Error进行合理的处理
	 */
	void handleError(ClientHttpResponse response) throws IOException;

	/**
	 * 默认的异常处理器
	 * 这里最终调用的还是上面的方法
	 * 当然可以重写这个方法
	 */
	default void handleError(URI url, HttpMethod method, ClientHttpResponse response) throws IOException {
		handleError(response);
	}

}

DefaultResponseErrorHandler

DefaultResponseErrorHandler实现的ResponseErrorHandler
它是restTemplate的默认异常处理器

  1. hasError方法—判断是否为异常
    在这里插入图片描述
    进入isError里可以看到restTemplate默认判断400一类(客户端)和500一类(服务端)为异常
    在这里插入图片描述
  2. handleError—对客户端和服务端错误抛出异常
    在这里插入图片描述

restTemplate是怎么调用的DefaultResponseErrorHandler

以下类容都是在RestTemplate类中

  1. restTemplate发送请求之后,调用handleResponse()方法
    在这里插入图片描述
  2. 进入handleResponse()方法,调用的getErrorHandler()
    在这里插入图片描述
  3. 进入getErrorHandler()–调用的本类的errorHandler
    在这里插入图片描述
  4. 再查看这个参数发现,restTemplate一开始建立后就是直接new 的一个DefaultResponseErrorHandler
    在这里插入图片描述
  5. 扩展
    由此可以明确的知道restTemplate是怎么使用的DefaultResponseErrorHandler
    那么我们怎么把自定义异常处理器的设置为默认的异常处理器呢?
    在RestTemplate中有一个异常处理器的setter方法,可以设置
    在这里插入图片描述
    如果你使用的是RestTemplateBuilder构建的restTemplate,在RestTemplateBuilder中有一个errorHandler可以设置
    在这里插入图片描述

ExtractingResponseErrorHandler

在这里插入图片描述

NoOpResponseErrorHandler

顾名思义:不进行处理
实现类在RestTemplate中

在这里插入图片描述
如何应用
当使用指定的凭据新建@link testresttemplate实例时,默认设置为这个处理器
在这里插入图片描述

自定义异常处理器

public class CustomErrorHandler implements ResponseErrorHandler {

    private static final Logger LOGGER = LoggerFactory.getLogger(CustomErrorHandler.class);

    /**
     * 返回false表示不管response的status是多少都返回没有错
     * 这里可以自己定义那些status code你认为是可以抛Error
     * Indicate whether the given response has any errors.
     * <p>Implementations will typically inspect the
     * {@link ClientHttpResponse#getStatusCode() HttpStatus} of the response.
     *
     * @param response the response to inspect
     * @return {@code true} if the response indicates an error; {@code false} otherwise
     * @throws IOException in case of I/O errors
     */
    @Override
    public boolean hasError(ClientHttpResponse response) throws IOException {
        return response.getStatusCode().value() != 200 && response.getStatusCode().value() !=302;
    }

    /**
     * 这里面可以实现你自己遇到了Error进行合理的处理
     * Handle the error in the given response.
     * <p>This method is only called when {@link #hasError(ClientHttpResponse)}
     * has returned {@code true}.
     *
     * @param response the response with the error
     * @throws IOException in case of I/O errors
     */
    @Override
    public void handleError(ClientHttpResponse response) throws IOException {

    }

    /**
     * 替代上面的方法
     * Alternative to {@link #handleError(ClientHttpResponse)} with extra
     * information providing access to the request URL and HTTP method.
     *
     * @param url      the request URL
     * @param method   the HTTP method
     * @param response the response with the error
     * @throws IOException in case of I/O errors
     * @since 5.0
     */
    @Override
    public void handleError(URI url, HttpMethod method, ClientHttpResponse response) throws IOException {
        LOGGER.error("=======================ERROR============================");
        LOGGER.error("DateTime:{}", DateUtil.generateTimeFormatter(response.getHeaders().getDate(),"yyyy-MM-dd HH:mm:ss"));
        LOGGER.error("HOST:{},URI:{}", url.getHost(),url.getPath());
        LOGGER.error("Method:{}", method.name());
        LOGGER.error("Exception:{}", response.getStatusCode());
        LOGGER.error("========================================================");
    }
}

在这里插入图片描述
自定义异常例子源码地址

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Spring Cloud中,我们可以通过自定义全局异常处理来处理应用程序中的所有异常。以下是实现全局异常处理的步骤: 1. 创建一个全局异常处理类,该类应该实现Spring的ErrorController接口。 2. 在处理类中,使用@RequestMapping注解来定义处理所有错误请求的路由。 3. 在路由方法中,获取请求中的异常信息,并根据异常类型返回相应的错误响应。 4. 在应用程序的配置文件中,将Spring的默认错误处理禁用,并将全局异常处理类注册为错误处理。 以下是一个简单的全局异常处理示例: ``` @RestController @ControllerAdvice public class GlobalExceptionHandler implements ErrorController { @RequestMapping("/error") public ResponseEntity<ErrorResponse> handleAllExceptions(HttpServletRequest request) { ErrorResponse errorResponse = new ErrorResponse(); errorResponse.setErrorCode(HttpStatus.INTERNAL_SERVER_ERROR.value()); errorResponse.setErrorMessage("An error occurred during the request."); errorResponse.setRequestedURI(request.getRequestURI()); return new ResponseEntity<>(errorResponse, HttpStatus.INTERNAL_SERVER_ERROR); } @Override public String getErrorPath() { return "/error"; } } ``` 在上面的代码中,我们实现了Spring的ErrorController接口,并使用@ControllerAdvice注解来指定该类为全局异常处理。在handleAllExceptions方法中,我们获取请求中的异常信息,并根据异常类型返回相应的错误响应。最后,我们将该类注册为错误处理,并将Spring的默认错误处理禁用。 ### 回答2: Spring Cloud是一个用于构建微服务架构的框架,它提供了许多功能和组件来简化微服务的开发和管理。其中之一就是全局异常处理。 全局异常处理是一个用于捕获和处理应用程序中发生的异常的组件。在微服务架构中,由于各个服务之间的调用和交互,很可能会出现许多不同种类的异常,例如网络异常、数据库异常、业务异常等。而全局异常处理的作用就是捕获这些异常,并根据具体情况进行统一处理。 使用Spring Cloud的全局异常处理,可以帮助我们实现以下功能: 1. 统一异常处理:无论是哪个服务发生了异常,全局异常处理都能捕获并进行处理,避免异常导致系统崩溃或无响应。 2. 异常信息返回:全局异常处理可以将捕获到的异常信息封装成特定的响应格式,方便客户端或其他服务进行处理。 3. 异常分类处理:根据异常的类型和来源,全局异常处理可以将异常分类处理,例如数据库异常可以跳转到指定的错误页面,业务异常可以返回特定的错误码等。 4. 日志记录:全局异常处理可以将捕获到的异常信息进行日志记录,方便开发人员进行问题排查和分析。 总之,Spring Cloud的全局异常处理是一个非常实用的组件,能够帮助我们捕获和处理微服务架构中的异常,并保证系统的稳定性和可靠性。通过合理配置和使用全局异常处理,我们可以更好地管理和维护我们的微服务应用程序。 ### 回答3: Spring Cloud全局异常处理是用来统一处理系统中出现的异常情况。在微服务架构中,由于系统由多个服务组成,每个服务都可能出现异常,如果每个服务都单独处理异常,会造成代码冗余和维护困难。因此,引入全局异常处理可以统一处理所有服务的异常,提高代码的可维护性和可读性。 Spring Cloud全局异常处理的工作原理如下:首先,在服务启动时,通过配置文件或代码,将异常处理注册到Spring中。当服务中发生异常时,Spring会捕获到异常,并根据异常类型和处理的配置,将异常交给对应的处理进行处理。处理可以通过捕获异常的类型来判断异常的种类,并根据不同的异常类型进行不同的处理,例如返回给前端用户友好的错误信息、记录异常日志等。 使用全局异常处理的好处如下:首先,可以减少代码的冗余,不需要在每个服务中都编写相同的异常处理代码;其次,可以提高代码的可读性,将异常处理的逻辑集中在一个地方,便于理解和维护;还可以提高系统的容错性和稳定性,可以捕获并处理各种异常情况,避免系统因为异常导致崩溃或无法正常运行。 总结而言,Spring Cloud全局异常处理是一个集中处理系统中异常情况的机制,能够统一处理微服务架构中各个服务的异常,提高代码的可维护性和系统的容错性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值