我正在使用HttpClient通过API下载文件。当整个文件可以在一个请求中完成时,我能够正确地保存并打开文件。
当整个文件超过最大块大小时,我必须对API进行多次请求以获取文件,并且返回的是分块编码的数据。我的猜测是这些块没有被正确解码并保存到文件中,导致文件损坏。
是否有一种方法来对GetStreamAsync的响应进行分块解码?
public byte[] GetFileContent(File file)
{
var baseFileUri = BASE_URI + $"platform/files/{file.Id}";
int chunkSize = 128 * 1024;
chunkSize = file.NativeSize <= chunkSize ? file.NativeSize : chunkSize;
int start = 0;
using (MemoryStream stream = new MemoryStream())
{
while (start < file.NativeSize)
{
Get(baseFileUri, new List<KeyValuePair<string, string>>() { new KeyValuePair<string, string>("offset", start.ToString()), new KeyValuePair<string, string>("size", chunkSize.ToString()) }, stream);
start = start + chunkSize;
if (file.NativeSize < start + chunkSize)
{
chunkSize = file.NativeSize - start;
}
}
return stream.ToArray();
}
}
private void Get(string uri, List<KeyValuePair<string, string>> parameters, Stream stream)
{
var requestUri = BuildUriString(uri, parameters);
var methodResult = _client.GetStreamAsync(requestUri);
methodResult.Result.CopyTo(stream);
}