我有一个类似于这样的下载链接:
https://someURL.com/PiPki.aspx?ident=594907&jezik=de
下载结果可能是任何文件类型的文件,例如
Picture.jpg
或something.pdf
。如何能够下载这个链接后面的任何文件,并保留原始名称和扩展名?我有一个类似于这样的下载链接:
https://someURL.com/PiPki.aspx?ident=594907&jezik=de
Picture.jpg
或something.pdf
。如何能够下载这个链接后面的任何文件,并保留原始名称和扩展名?通过HTTP协议,不仅可以传输有效负载数据,还可以使用头部来传输元数据。在接收端,您可以使用该数据来确定存储文件的名称。
为了确定文件类型,HTTP响应必须具有正确的Content-Type
头(请参见此处)。如果传输的文件是PDF,则HTTP响应将具有标题字段。
Content-Type: application/pdf
Content-Disposition: attachment; filename="something.pdf"
Content-Type
,但没有文件名,则您可以使用默认文件名和与Content-Type
匹配的扩展名,例如download.pdf
。如果缺少或通用Content-Type
,则运气不佳。您可以尝试获取文件内容,但对于某些文件类型来说,这可能成功或不可靠。
由于这是一个C#问题
var client = new HttpClient();
using (var response = await client.GetAsync("https://someURL.com/PiPki.aspx?ident=594907&jezik=de"))
{
string fileName = null;
if (response.Headers.Contains("Content-Disposition"))
{
fileName = GetFileNameFromContentDisposition(response.Headers);
}
if (fileName == null && response.Headers.Contains("Content-Type"))
{
var extension = GetExtensionFromContentType(response.Headers);
fileName = $"download.{extension}";
}
using (var fileStream = File.OpenWrite(fileName))
{
await response.Content.CopyToAsync(fileStream);
}
}