我正在尝试从网址下载zip文件夹。该URL指向Sharepoint中包含文档集的库。如果将URL粘贴到浏览器中,则会下载zip文件。尝试从代码执行相同操作时,我只能下载32426个字节。我尝试了两种方法 - 一种是使用WebClient和其他WebRequest和响应的DownloadDataAsync()。这两个只读取32426字节,而zip文件夹接近6 MB。
using (var Webclient1 = new WebClient())
{
Webclient1.Headers.Add("Accept: text/html, application/xhtml+xml, */*");
Webclient1.Headers.Add("User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)");
byte[] data = null;
Webclient1.DownloadDataCompleted +=
delegate(object sender, DownloadDataCompletedEventArgs e)
{
data = e.Result;
};
Webclient1.DownloadDataAsync(uri);
while (Webclient1.IsBusy)
{
System.Threading.Thread.Sleep(10000);
}
var len = data.Length;
}
使用HttpRequest和响应
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(uri);
//request.Proxy.Credentials = System.Net.CredentialCache.DefaultCredentials;
request.Accept = @"text/html, application/xhtml+xml, */*";
request.UserAgent = @"Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0)";
request.Timeout = 1000000;
using (var response = request.GetResponse())
{
MemoryStream stream2 = new MemoryStream();
var stream = response.GetResponseStream();
stream.CopyTo(stream2);
return stream2.ToArray();
}
两者都读取不完整的内容。
答案 0 :(得分:0)
这应该有效:
public bool DownloadFile(string itemUrl, string localPath)
{
bool downloadSuccess = false;
try
{
using (IOFile.Stream itemFileStream = GetItemAsStream(itemUrl))
{
using (IOFile.Stream localStream = IOFile.File.Create(localPath))
{
itemFileStream.CopyTo(localStream);
downloadSuccess = true;
}
}
}
catch (Exception err)
{
}
return downloadSuccess;
}
protected IOFile.Stream GetItemAsStream(string itemUrl)
{
IOFile.Stream stream = null;
try
{
FileInformation fileInfo = File.OpenBinaryDirect(_context, itemUrl);
stream = fileInfo.Stream;
}
catch (Exception err)
{
throw new ApplicationException(string.Format("Error executing method {0}. {1}", MethodBase.GetCurrentMethod().Name, err.Message));
}
return stream;
}