• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

使用Ajax生成的Excel文件并下載

c# 搞代码 4年前 (2022-01-09) 17次浏览 已收录 0个评论

大家都應該知道,在ASP.NET MVC里,如果通過Ajax調用后臺控制器時,可以返回一個JSON對象,但并不能直接返回文件(除非刷新頁面,那就不是Ajax啦),所以如果想用Ajax生成文件并下載的話,那只要將生成的文件先保存到服務器上,然後再將文件路徑通過JSON返回,之後才可以進行下載,當然由於是暫時性存放,所以當下載完后就需要馬上刪除相應的文件。

以下是做法以動態生成Excel為例(生成Excel的具體步驟我就省略了,這并不是此文章的重點):

1. 首先創建Action生成Excel文件

[HttpPost]public JsonResult ExportExcel(){    DataTable dt = DataService.GetData();    var fileName = "Excel_" + DateTime.Now.ToString("yyyyMMddHHmm") + ".xls";    //將生成的文件保存到服務器的臨時目錄里    string fullPath = Path.Combine(Server.MapPath("~/temp"), fileName);     using (var exportData = new MemoryStream())    {        //如何生成Excel這里就不詳細說明啦,我這里對Excel的操作使用的是 NPOI        Utility.WriteDataTableToExcel(dt, ".xls", exportData);         FileStream file = new FileStream(fullPath, FileMode.Create, FileAccess.Write);        exportData.WriteTo(file);        file.Close();    }     var errorMessage = "you can return the errors in here!";     //返回生成的文件名    return Json(new { fileName = fileName, errorMessage = "" });}

2. 創建下載用的 Action

[HttpGet][DeleteFileAttribute] //Action Filter, 下載完后自動刪除文件,這個屬性稍後解釋public ActionResult Download(string file){    //到服務器臨時文件目錄下載相應的文件    string fullPath = Path.Combine(Server.MapPath("~/temp"), file);    //返回文件對象,這里用的是Excel,所以文件頭使用了 "application/vnd.ms-excel"    return File(fullPath, "application/vnd.ms-excel", file);}

3. 由於要做到下載完后自動刪除文件,所以再創建一個 Action Filter

public class DeleteFileAttribute : ActionFilterAttribute{    public override void OnResultExecuted(ResultExecutedContext filterContext)    {        filterContext.HttpContext.Response.Flush();        //將當前filter context轉換成具體操作的文件并獲取文件路徑        string filePath = (filterContext.Result as FilePathResult).FileName;        //有文件路徑后就可以直接刪除相關文件了        System.IO.File.Delete(filePat<em>本文来源gao.dai.ma.com搞@代*码(网$</em>h);    }}

4. 最后在前臺添加 Ajax 調用的代碼:

//這里我使用了 blockUI 做loading...$.blockUI({ message: '<h3>Please wait a moment...</h3>' });    $.ajax({    type: "POST",    url: '@Url.Action("ExportExcel","YourController")', //調用相應的controller/action    contentType: "application/json; charset=utf-8",    dataType: "json",}).done(function (data) {    //console.log(data.result);    $.unblockUI();    //接收返回的文件路徑,此文件這時已保存到服務器上了    if (data.fileName != "") {        //通過調用 window.location.href 直接跳轉到下載 action 進行文件下載操作        window.location.href = "@Url.RouteUrl(new { Controller = "YourController", Action = "Download"})/?file=" + data.fileName;    }});

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:使用Ajax生成的Excel文件并下載
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址