【发布时间】:2018-07-26 17:55:48
【问题描述】:
我正在使用 API 使用 HttpClient 下载文件。当我的整个文件适合单个请求时,我可以保存文件并正确打开它。
当整个文件不适合我的最大块大小时,我必须向我的 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);
}
【问题讨论】:
-
Stream.CopyTo 已经进行了分块(默认大小为 81920 referencesource.microsoft.com/#mscorlib/system/io/…)。
标签: c# .net-core dotnet-httpclient