使用Ajax生成的Excel文件并下载的实例
很久沒有寫文章啦,今天分享一個如何在ASP.NETMVC里使用Ajax下載生成文件的方法,以下只是個人心得:
大家都應該知道,在ASP.NETMVC里,如果通過Ajax調用后臺控制器時,可以返回一個JSON對象,但并不能直接返回文件(除非刷新頁面,那就不是Ajax啦),所以如果想用Ajax生成文件并下載的話,那只要將生成的文件先保存到服務器上,然後再將文件路徑通過JSON返回,之後才可以進行下載,當然由於是暫時性存放,所以當下載完后就需要馬上刪除相應的文件。
以下是做法以動態生成Excel為例(生成Excel的具體步驟我就省略了,這并不是此文章的重點):
1.首先創建Action生成Excel文件
[HttpPost]
publicJsonResultExportExcel()
{
DataTabledt=DataService.GetData();
varfileName="Excel_"+DateTime.Now.ToString("yyyyMMddHHmm")+".xls";
//將生成的文件保存到服務器的臨時目錄里
stringfullPath=Path.Combine(Server.MapPath("~/temp"),fileName);
using(varexportData=newMemoryStream())
{
//如何生成Excel這里就不詳細說明啦,我這里對Excel的操作使用的是NPOI
Utility.WriteDataTableToExcel(dt,".xls",exportData);
FileStreamfile=newFileStream(fullPath,FileMode.Create,FileAccess.Write);
exportData.WriteTo(file);
file.Close();
}
varerrorMessage="youcanreturntheerrorsinhere!";
//返回生成的文件名
returnJson(new{fileName=fileName,errorMessage=""});
}
2.創建下載用的Action
[HttpGet]
[DeleteFileAttribute]//ActionFilter,下載完后自動刪除文件,這個屬性稍後解釋
publicActionResultDownload(stringfile)
{
//到服務器臨時文件目錄下載相應的文件
stringfullPath=Path.Combine(Server.MapPath("~/temp"),file);
//返回文件對象,這里用的是Excel,所以文件頭使用了"application/vnd.ms-excel"
returnFile(fullPath,"application/vnd.ms-excel",file);
}
3.由於要做到下載完后自動刪除文件,所以再創建一個ActionFilter
publicclassDeleteFileAttribute:ActionFilterAttribute
{
publicoverridevoidOnResultExecuted(ResultExecutedContextfilterContext)
{
filterContext.HttpContext.Response.Flush();
//將當前filtercontext轉換成具體操作的文件并獲取文件路徑
stringfilePath=(filterContext.ResultasFilePathResult).FileName;
//有文件路徑后就可以直接刪除相關文件了
System.IO.File.Delete(filePath);
}
}
4.最后在前臺添加Ajax調用的代碼:
//這里我使用了blockUI做loading...
$.blockUI({message:'<h3>Pleasewaitamoment...</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;
}
});
5.完!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。