//第一步,将文件名,路径单独存入一张表,(为防止文件重复,路径后加一个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了。