Openfeign ErrorDecoder导致java.io.IOException:流已关闭

当我尝试实现ErrorDecoder来解码假异常时,我发现response.body()中的流是关闭的,所以当我尝试读取流并转换为字符串时,它抛出java.io.IOException: stream is closed。这真的很困惑,因为在解码器之前,我没有做任何事情来提前关闭流。

Stack Overflow用户

发布于 2020-06-05 02:02:26

我经历了这个噩梦,这都是IDE的错。

调试模式中的断点在导致流关闭的response.body().asReader结束/之前。

只需在读取正文后开始调试,一切都很顺利。

Stack Overflow用户

发布于 2020-09-22 19:31:07

记录器/ System.out.println /集成开发环境调试模式

在获取response.body()之前,不要使用上述任何功能

如果您使用上面的任何特性来打印/记录/查看您的response对象,那么它将在内部处理response.body()并关闭InputStream。因此,在这种情况下,您将得到Stream is closed错误。

要解决此问题,请在记录器之前处理response.body()。现在,您可以通过运行应用程序来检查这一点,但不能在调试模式下运行。

示例代码:

复制代码
@Override
  public Exception decode(final String methodKey, final Response response) {
    final String error = getResponseBodyAsString(response.body());
    LOGGER.error("{} failed with response {}", methodKey, response);
    return new ServiceException("Request failed with status: " + response.status()
                                                         + " and error: " + error);
  }

  private String getResponseBodyAsString(final Response.Body body) {
    try {
      return IOUtils.toString(body.asReader(StandardCharsets.UTF_8));
    } catch (final IOException e) {
      LOGGER.error("Failed to read the response body with error: ", e);
    }
    return null;
  }

注意:如果您处于调试模式,那么您的想法将处理此响应,因此即使在这种情况下,您也会得到相同的错误。因此,请不要在调试模式下检查此选项。

原文链接:Openfeign ErrorDecoder导致java.io.IOException:流已关闭-腾讯云开发者社区-腾讯云

相关推荐
一个处女座的程序猿O(∩_∩)O17 小时前
Python多重继承详解
开发语言·python
SmartBrain17 小时前
技术总结:VLLM部署Qwen3模型的详解
开发语言·人工智能·算法·vllm
玄〤17 小时前
枚举问题的两大利器:深度优先搜索(DFS)与下一个排列(Next Permutation)算法详解(Java版本)(漫画解析)
java·算法·深度优先·dfs
wuqingshun31415917 小时前
HashMap的长度为什么是2的N次方呢?
java·开发语言·jvm
岱宗夫up17 小时前
【前端基础】HTML + CSS + JavaScript 基础(二)
开发语言·前端·javascript·css·架构·前端框架·html
indexsunny17 小时前
互联网大厂Java面试实录:Spring Boot与微服务在电商场景中的应用
java·jvm·spring boot·微服务·面试·mybatis·电商
予枫的编程笔记17 小时前
【Kafka基础篇】Kafka高可用核心:ISR机制与ACK策略详解,吃透可靠性与吞吐量权衡
java·kafka·消息队列·高可用·分布式系统·isr机制·ack策略
时717 小时前
Java 版本管理工具:Jabba
java
开源fly17 小时前
Java泛型和类型擦除
java
Mr -老鬼17 小时前
RustSalvo框架上传文件接口(带参数)400错误解决方案
java·前端·python