您可能知道在HTTP标头中发送分块文件,没有内容长度,因此程序必须等待0才能理解该文件已结束。
--sample http header
POST /some/path HTTP/1.1
Host: www.example.com
Content-Type: text/plain
Transfer-Encoding: chunked
25
This is the data in the first chunk
8
sequence
0
用于接收此文件,可以使用以下代码。
ResponseHandler<String> reshandler = new ResponseHandler<String>() {
public String handleResponse(HttpResponse response) throws ClientProtocolException, IOException {
HttpEntity entity = response.getEntity();
InputStream in = entity.getContent();
byte[] b = new byte[500];
StringBuffer out = new StringBuffer();
int len = in.read(b);
out.append(new String(b, 0 , len));
return out.toString();
}
};
但在我的情况下,我使用流媒体通道,换句话说没有0显示该文件已结束。无论如何,如果我使用这个代码,它似乎永远等待0永远不会发生。我的问题是有没有更好的方法从流通道接收分块文件?
答案 0 :(得分:1)
确定。我可以使用简单的方法接收数据(如下所示,不使用Response Handler)。无论如何,我仍然有点混淆apache ChunkedInputStream以及它是如何使用的,而normall inputstream可以处理分块数据。
is = entity.getContent();
StringBuffer out = new StringBuffer();
byte[] b = new byte[800];
int len = is.read(b);
out.append(new String(b, 0 , len));
result = out.toString();