这是我的代码
Uri uri = new Uri(this.Url);
var data = client.DownloadData(uri);
if (!String.IsNullOrEmpty(client.ResponseHeaders["Content-Disposition"]))
{
FileName = client.ResponseHeaders["Content-Disposition"].Substring(client.ResponseHeaders["Content-Disposition"].IndexOf("filename=") + 10).Replace("\"", "");
}
如何在不下载文件的情况下获取文件名,我的意思是不使用client.DownloadData
??
最佳答案
WebClient 不会支持它,但是使用 HttpWebRequest,如果服务器支持它,您可以尝试友好地发送 HEAD 请求,或者如果它不发送正常的 GET 请求并且不下载数据:
HEAD 请求:
HttpWebRequest request = (HttpWebRequest)System.Net.WebRequest.Create(uri);
request.Method = "HEAD";
HttpWebResponse response = (HttpWebResponse) request.GetResponse();
string disposition = response.Headers["Content-Disposition"];
string filename = disposition.Substring(disposition.IndexOf("filename=") + 10).Replace("\"", "");
response.close();
如果服务器不支持HEAD,则发送普通的GET请求:
HttpWebRequest request = (HttpWebRequest)System.Net.WebRequest.Create(uri);
HttpWebResponse response = (HttpWebResponse) request.GetResponse();
string disposition = response.Headers["Content-Disposition"];
string filename = disposition.Substring(disposition.IndexOf("filename=") + 9).Replace("\"", "");
response.close();
关于c# - 如何从URL获取文件名而不下载文件c#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44859016/