我曾尝试使用 HttpWebResponse.GetResponse();
但这不是 .NET 核心的一部分,我想不出其他任何东西。
到目前为止我只有这个,但这会下载整个文件
string first_line(string url)
{
var httpClient = new HttpClient();
httpClient.DefaultRequestHeaders.UserAgent.Add(new ProductInfoHeaderValue("MyClient", "1.0"));
var otp = httpClient.GetStringAsync(url);
return imaginary_first_line;
}
我想只下载第一行而不下载文件的其余部分。
最佳答案
解决方案是使用Range header 。它说我们只对文件的一部分感兴趣的服务器。这是一个仅下载 50 个字节的示例:
using (var client = new HttpClient())
{
var request = new HttpRequestMessage(HttpMethod.Get, url);
//Let's read only 50 bytes
request.Headers.Range = new RangeHeaderValue(0, 50);
using (var response = await client.SendAsync(request))
using (var stream= await response.Content.ReadAsStreamAsync())
{
//The buffer can store 1000 bytes but only 50 will be send from the server
var buffer = new byte[1000];
stream.Read(buffer, 0, 1000);
//...
}
}
您可以使用 Fiddler 检查服务器是否真的只返回 50 个字节。
您还可以按以下方式使用 HttpWebRequest 类:
var request = (HttpWebRequest)WebRequest.Create(url);
request.Headers[HttpRequestHeader.Range] = "bytes=0-50";
var response = await request.GetResponseAsync();
//...
结果应该是一样的。
关于c# - 如何在 .NET Core 中逐行下载文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40648914/