• 技术文章 >后端开发 >C#.Net教程

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

    高洛峰高洛峰2016-11-19 10:39:47原创1564
    大家都應該知道,在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(filePath);
        }
    }

    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;
        }
    });


    php入门到就业线上直播课:查看学习

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:Ajax
    上一篇:C#图像处理绘制公章 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• c语言标识符有哪些类型• c语言中源文件编译后生成什么文件• c语言本身有没有输入输出语句• c语言中的标识符是由什么组成• c语言中*p和p的区别是什么
    1/1

    PHP中文网