使用HttpClient的时候报错java.io.IOException: Attempted read from closed stream

使用HttpClient的时候报错java.io.IOException: Attempted read from closed stream

问题背景

使用HttpClient的时候报错java.io.IOException: Attempted read from closed stream

2022-01-21 14:48:30.627 ERROR 32956 --- [           main] c.dz.marketservice.util.HttpClientPool   : =============["异常"]======================, e: {}

java.io.IOException: Attempted read from closed stream.
	at org.apache.http.impl.io.ContentLengthInputStream.read(ContentLengthInputStream.java:165) ~[httpcore-4.4.15.jar:4.4.15]
	at org.apache.http.conn.EofSensorInputStream.read(EofSensorInputStream.java:135) ~[httpclient-4.5.13.jar:4.5.13]
	at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284) ~[na:1.8.0_221]
	at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326) ~[na:1.8.0_221]
	at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178) ~[na:1.8.0_221]
	at java.io.InputStreamReader.read(InputStreamReader.java:184) ~[na:1.8.0_221]
	at java.io.Reader.read(Reader.java:140) ~[na:1.8.0_221]
	at org.apache.http.util.EntityUtils.toString(EntityUtils.java:227) ~[httpcore-4.4.15.jar:4.4.15]
	at org.apache.http.util.EntityUtils.toString(EntityUtils.java:308) ~[httpcore-4.4.15.jar:4.4.15]
	at com.dz.marketservice.util.HttpClientPool.postForJsonObject(HttpClientPool.java:127) ~[classes/:na]
	at com.dz.marketservice.client.HttpTest.packageReq(HttpTest.java:63) [classes/:na]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_221]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_221]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_221]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_221]
	at org.junit.platform.commons.util.ReflectionUtils.invokeMethod(ReflectionUtils.java:725) [junit-platform-commons-1.8.2.jar:1.8.2]

java.lang.NullPointerException
	at com.dz.marketservice.client.HttpTest.packageReq(HttpTest.java:64)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.junit.platform.commons.util.ReflectionUtils.invokeMethod(ReflectionUtils.java:725)
	at org.junit.jupiter.engine.execution.MethodInvocation.proceed(MethodInvocation.java:60)

解决方案

1 看错误Attempted read from closed stream翻译过来就是:从已经关闭的流中尝试再次读取,根据这条报错,我去看了我的代码

System.out.println(EntityUtils.toString(response.getEntity()));
JSONObject result = JSONObject.parseObject(EntityUtils.toString(response.getEntity()));

2 为了方便我自己加入了一条打印,重复使用了response.getEntity(),但是这个获取只能获取一次,就像发布与消费,当中间的消息消费掉了,再去使用,找不到就报错了,所以这条语句可以改成:

String temp = EntityUtils.toString(response.getEntity());
System.out.println(temp);
JSONObject result = JSONObject.parseObject(temp));

心得

  • 耐心读一下报错信息,好好理解一下,也能自己解决问题




作为程序员第 30 篇文章,每次写一句歌词记录一下,看看人生有几首歌的时间,wahahaha …

Lyric: 我们愉快的梦游

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值