SharePoint中的文件下载(.Net文件下载,支持大文件)

今天折腾了一天,就在折腾这个下载.由于SharePoint中的文件都是存在数据库中的,没有实体路径,导致好多种方式的文件下载不能用,只能使用写出文件流的方式来下载,进过百般折腾后找到以下代码,在此作为记录

下面是原始代码:

 System.IO.Stream iStream = null;
 
 // Buffer to read 10K bytes in chunk:
 byte[] buffer = new Byte[10000];
 
 // Length of the file:
 int length;
 
 // Total bytes to read:
 long dataToRead;
 
 // Identify the file to download including its path.
 string filepath = "DownloadFileName";
 
 // Identify the file name.
 string filename = System.IO.Path.GetFileName(filepath);
 
 try {
     // Open the file.
     iStream = new System.IO.FileStream(filepath, System.IO.FileMode.Open,
     System.IO.FileAccess.Read, System.IO.FileShare.Read);
 
 
     // Total bytes to read:
     dataToRead = iStream.Length;
 
     Response.ContentType = "application/octet-stream";
     Response.AddHeader("Content-Disposition", "attachment; filename=" + filename);
 
     // Read the bytes.
     while (dataToRead > 0) {
         // Verify that the client is connected.
         if (Response.IsClientConnected) {
             // Read the data in buffer.
             length = iStream.Read(buffer, 0, 10000);
 
             // Write the data to the current output stream.
             Response.OutputStream.Write(buffer, 0, length);
 
             // Flush the data to the HTML output.
             Response.Flush();
 
             buffer = new Byte[10000];
             dataToRead = dataToRead - length;
         } else {
             //prevent infinite loop if user disconnects
             dataToRead = -1;
         }
     }
 } catch (Exception ex) {
     // Trap the error, if any.
     Response.Write("Error : " + ex.Message);
 } finally {
     if (iStream != null) {
         //Close the file.
         iStream.Close();
     }
 }

 

以下是修改过的SharePoint代码:

 System.IO.Stream iStream = null;
 
 // Buffer to read 10K bytes in chunk:
 byte[] buffer = new Byte[10000];
 SPFile file = SPContext.Current.Web.GetFile("FileGuid Or FileUrl");
 // Length of the file:
 int length;
 
 // Total bytes to read:
 long dataToRead;
 
 
 
 
 // Identify the file name.
 string filename = file.Name;
 
 try {
     // Open the file.
     iStream = file.OpenBinaryStream();
     
  
 
     // Total bytes to read:
     dataToRead = file.Length;
 
     Response.ContentType = "application/octet-stream";
     Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(file. Name, Syste m.Text.Encoding.UTF8));
 
     // Read the bytes.
     while (dataToRead > 0) {
         // Verify that the client is connected.
         if (Response.IsClientConnected) {
             // Read the data in buffer.
             length = iStream.Read(buffer, 0, 10000);
 
             // Write the data to the current output stream.
             Response.OutputStream.Write(buffer, 0, length);
 
             // Flush the data to the HTML output.
             Response.Flush();
 
             buffer = new Byte[10000];
             dataToRead = dataToRead - length;
         } else {
             //prevent infinite loop if user disconnects
             dataToRead = -1;
         }
     }
 } catch (Exception ex) {
     // Trap the error, if any.
     Response.Write("Error : " + ex.Message);
 } finally {
     if (iStream != null) {
         //Close the file.
         iStream.Close();
     }
 }

 

转载于:https://www.cnblogs.com/masahiro/archive/2011/11/04/10130412.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是用C#编写的用于下载文件SharePoint代码: ```csharp using System; using System.IO; using Microsoft.SharePoint.Client; namespace SharePointDownloader { class Program { static void Main(string[] args) { string siteUrl = "https://your-sharepoint-site-url"; string filePath = "Shared Documents/FileName.txt"; string savePath = @"C:\Downloads\"; using (ClientContext clientContext = new ClientContext(siteUrl)) { // 设置凭据 clientContext.Credentials = new System.Net.NetworkCredential("username", "password"); // 获取文件 FileInformation fileInformation = Microsoft.SharePoint.Client.File.OpenBinaryDirect(clientContext, filePath); // 构建本地保存路径 string localFilePath = Path.Combine(savePath, Path.GetFileName(filePath)); using (FileStream fileStream = new FileStream(localFilePath, FileMode.Create)) { // 下载文件 fileInformation.Stream.CopyTo(fileStream); Console.WriteLine("文件成功下载至:" + localFilePath); } } } } } ``` 上述代码使用了SharePoint的客户端对象模型(Client Object Model)来进行文件下载。首先需要提供SharePoint网站的URL、要下载文件路径和要保存的本地路径。然后,使用`ClientContext`创建一个与SharePoint网站的连接,并设置凭据来进行身份验证。 接下来,使用`File.OpenBinaryDirect`方法打开要下载文件,并获取文件的信息。然后,根据提供的本地保存路径,使用`FileStream`在本地创建一个文件流。最后,利用文件流的`CopyTo`方法将从SharePoint下载文件流写入到本地文件,实现文件下载。 在代码可以替换以下的参数来满足您的实际需求: - `siteUrl`:SharePoint网站的URL。 - `filePath`:要下载文件SharePoint的路径。 - `savePath`:要保存的本地路径。 - `username`和`password`:进行身份验证的用户名和密码。 请注意,为了使用SharePoint的客户端对象模型,您需要在项目引用`Microsoft.SharePoint.Client`和`Microsoft.SharePoint.Client.Runtime`的程序集,并添加相应的命名空间引用。 希望以上回答对您有所帮助,如有任何疑问,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值