//第一步,將文件名,路徑單獨存入一張表,(為防止文件重復,路徑后加一個guid命名的文件夾)
protected void btnSave_Click(object sender, EventArgs e) { if (!File1.HasFile) { Alert("請選擇文件!"); return; } string filename = File1.FileName; string savedPath = System.Configuration.ConfigurationManager.AppSettings["UploadFilePath"] + Guid.NewGuid().ToString("N"); try { File1.SaveAs(Server.MapPath(savedPath)); } catch { Alert("文件上傳失敗!"); return; } string guid = EFContext.Current.ISystemService.ISysFileService.Upload(filename, savedPath, int.Parse(EFContext.Current.UserIdentity)); AddFile(guid); }
DbCommand dbc = SqlDB.GetStoredProcCommand(sqlCommand); SqlDB.AddInParameter(dbc, "Name", SqlDbType.NVarChar, entity.Name); SqlDB.AddInParameter(dbc, "Url", SqlDbType.NVarChar, entity.Url); SqlDB.AddInParameter(dbc, "Created", SqlDbType.DateTime, entity.Created); SqlDB.AddInParameter(dbc, "CreatedBy", SqlDbType.Int, entity.CreatedBy); SqlDB.AddOutParameter(dbc, "Id", SqlDbType.Char,36);
返回guid存入存放文件詳細信息的表中
下載文件時根據此guid去讀取文件路徑和文件名
using System; using System.Collections.Generic; using System.Linq; using System.Web; using Microsoft.Practices.Unity; using System.Text; using WelderQualification.Models; namespace WelderQualification.Components { public class FileDownloadHandler : EFDataHandler { public override void DataEvent(HttpContext context) { string guid = context.Request.QueryString["guid"]; if (string.IsNullOrEmpty(guid)) return; guid = guid.Trim(); if (guid.Length != 36) return; SysFileInfo info=EFContext.Current.ISystemService.ISysFileService.Get(guid); if(info==null||info.CreatedBy==0) return; System.IO.FileInfo fileInfo = new System.IO.FileInfo(context.Server.MapPath(info.Url)); if (fileInfo.Exists) { int ChunkSize = 102400;//100K 每次讀取文件,只讀取100K,這樣可以緩解服務器的壓力 byte[] buffer = new byte[ChunkSize]; context.Response.Clear(); System.IO.FileStream iStream = System.IO.File.OpenRead(fileInfo.FullName); long dataLengthToRead = iStream.Length;//獲取下載的文件總大小 context.Response.ContentType = "application/octet-stream"; context.Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(info.Name)); while (dataLengthToRead > 0 && context.Response.IsClientConnected) { int lengthRead = iStream.Read(buffer, 0, ChunkSize);//讀取的大小 context.Response.OutputStream.Write(buffer, 0, lengthRead); context.Response.Flush(); dataLengthToRead = dataLengthToRead - lengthRead; } iStream.Close(); context.Response.Close(); } } } }
見一個ashx頁面:
<%@ WebHandler Language="C#" Class="WelderQualification.Components.FileDownloadHandler" %>
頁面綁定
<a href='/FileDownLoad.ashx?guid=<%# DataBinder.Eval(Container.DataItem, "Url")%>' target="_blank">
這樣就OK了。