gpt4 book ai didi

java - 使用http客户端时流关闭

转载 作者:行者123 更新时间:2023-12-02 07:48:56 30 4
gpt4 key购买 nike

使用 httpclient 获取响应时出现在线错误 out.write(EntityUtils.toString(resEntity));//这是java代码中的第70行

为什么会出现这种情况?

    CloseableHttpClient httpClient = HttpClients.custom().setUserAgent("Mozilla/5.0 (Windows NT 6.3; rv:36.0) Gecko/20100101 Firefox/36.0").build();
HttpResponse response = httpClient.execute(new HttpGet(searchLink.toString()));
HttpEntity resEntity = response.getEntity();
System.out.println(EntityUtils.toString(resEntity));
PrintWriter out = new PrintWriter(new File("searchResult.xml"));
out.write(EntityUtils.toString(resEntity));
out.flush();
out.close();
httpClient.close();

错误是

2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) java.io.IOException: Stream closed
2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) at java.util.zip.GZIPInputStream.ensureOpen(GZIPInputStream.java:61)
2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) at java.util.zip.GZIPInputStream.read(GZIPInputStream.java:112)
2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) at org.apache.http.client.entity.LazyDecompressingInputStream.read(LazyDecompressingInputStream.java:74)
2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:283)
2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:325)
2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:177)
2015/08/07 13:03:12,887 ERROR [stderr] (Thread-101) at java.io.InputStreamReader.read(InputStreamReader.java:184)
2015/08/07 13:03:12,888 ERROR [stderr] (Thread-101) at java.io.Reader.read(Reader.java:140)
2015/08/07 13:03:12,888 ERROR [stderr] (Thread-101) at org.apache.http.util.EntityUtils.toString(EntityUtils.java:244)
2015/08/07 13:03:12,888 ERROR [stderr] (Thread-101) at org.apache.http.util.EntityUtils.toString(EntityUtils.java:288)
2015/08/07 13:03:12,888 ERROR [stderr] (Thread-101) at mainThread.Search.doRequest(Search.java:70)
2015/08/07 13:03:12,888 ERROR [stderr] (Thread-101) at mainThread.Search.search(Search.java:29)
...

同时线上成功收到请求的响应

System.out.println(EntityUtils.toString(resEntity));

最佳答案

您无法读取响应流两次,这就是您通过有效调用 EntityUtils.toString(resEntity) 两次所做的事情。

System.out.println(EntityUtils.toString(resEntity)); // once
// ...
out.write(EntityUtils.toString(resEntity)); // twice

当您到达第二次时,响应流已经没有更多数据可供读取。

在这种情况下,只需确保通过将结果字符串分配给变量来读取响应流一次。然后,您可以根据需要多次安全地使用该字符串变量。

String resEntityToString = EntityUtils.toString(resEntity);
System.out.println(resEntityToString);
// ...
out.write(resEntityToString);

关于java - 使用http客户端时流关闭,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31883302/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com