Content-Length 分隔消息正文过早结束(预期:

新手上路,请多包涵

我试图在 apache httpclient 的帮助下获得 HTTP 响应。我成功获取了标头,但是当我尝试获取内容时它抛出异常。例外是:

  org.apache.http.ConnectionClosedException: Premature end of Content-Length delimited message body (expected: 203856; received: 1070
        at org.apache.http.impl.io.ContentLengthInputStream.read(ContentLengthInputStream.java:180)
        at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:283)
        at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:325)
        at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:177)
        at java.io.InputStreamReader.read(InputStreamReader.java:184)
        at java.io.BufferedReader.fill(BufferedReader.java:154)
        at java.io.BufferedReader.readLine(BufferedReader.java:317)
        at java.io.BufferedReader.readLine(BufferedReader.java:382)

我的代码是:

 InputStream is = entity.getContent();
BufferedReader br = new BufferedReader( new InputStreamReader(is, "UTF-8"));
String line;
String str = "";
while ((line = br.readLine()) != null) {

    str = str + line + "\n";

}
log.debug(str);

任何帮助将不胜感激。谢谢

原文由 Khanjee 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 2.5k
2 个回答

问题似乎出在服务器端,而不是您粘贴的客户端代码中。

服务器声称内容包含 203856 字节,但只发送了 1070。

原文由 Daniel Renshaw 发布,翻译遵循 CC BY-SA 3.0 许可协议

我可能会晚点回复它。但是我也遇到了同样的问题。我得到了解决方案。在我的例子中,我在使用 HttpEntity 之前关闭了客户端。关闭客户端后,我试图下载文件。下面的代码与我所做的类似:

 HttpEntity httpEntity = null;
try (final CloseableHttpClient client = createHttpClient()) {
     httpEntity = getEntity(client);
}

return downloadFile(httpEntity, targetDirectory, fileName);

在关闭客户端之前调整我的代码以下载文件后,它现在对我有用。下面的代码类似于我现在所做的:

 try (final CloseableHttpClient client = createHttpClient()) {
     HttpEntity httpEntity = getEntity(client);
     return downloadFile(httpEntity, targetDirectory, fileName);
}

原文由 Nitin Singhal 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏