我曾尝试使用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;
}
我只想下载没有文件其余部分的第一行。
答案 0 :(得分:3)
解决方案是使用 Range 标头。它说我们只对文件的一部分感兴趣的服务器。下面是一个只下载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();
//...
结果应该是一样的。