使用Ajax生成的Excel文件并下载的实例
很久]有文章啦,今天分享一如何在ASP.NET MVC里使用Ajax下d生成文件的方法,以下只是人心得:
大家都知道,在ASP.NET MVC里,如果通^Ajax{用后_控制器r,可以返回一JSONο螅⒉荒苤苯臃祷匚募ǔ撬⑿马面,那就不是Ajax啦),所以如果想用Ajax生成文件并下d的,那只要⑸傻奈募缺4娴椒掌魃希会嵩⑽募通^JSON返回,之後才可以M行下d,然由於是r性存放,所以下d完后就需要R上h除相奈募
以下是做法以B生成Excel槔ㄉExcel的具w步E我就省略了,@并不是此文章的重c):
1. 首先建Action生成Excel文件
[HttpPost]
public JsonResult ExportExcel()
{
DataTable dt = DataService.GetData();
var fileName = "Excel_" + DateTime.Now.ToString("yyyyMMddHHmm") + ".xls";
//⑸傻奈募4娴椒掌鞯呐Rr目里
string fullPath = Path.Combine(Server.MapPath("~/temp"), fileName);
using (var exportData = new MemoryStream())
{
//如何生成Excel@里就不f明啦,我@里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. 建下d用的 Action
[HttpGet]
[DeleteFileAttribute] //Action Filter, 下d完后自h除文件,@傩陨葬峤忉
public ActionResult Download(string file)
{
//到服掌髋Rr文件目下d相奈募
string fullPath = Path.Combine(Server.MapPath("~/temp"), file);
//返回文件ο螅@里用的是Excel,所以文件^使用了 "application/vnd.ms-excel"
return File(fullPath, "application/vnd.ms-excel", file);
}3. 由於要做到下d完后自h除文件,所以再建一 Action Filter
public class DeleteFileAttribute : ActionFilterAttribute
{
public override void OnResultExecuted(ResultExecutedContext filterContext)
{
filterContext.HttpContext.Response.Flush();
//前filter contextDQ成具w操作的文件并@取文件路
string filePath = (filterContext.Result as FilePathResult).FileName;
//有文件路后就可以直接h除相P文件了
System.IO.File.Delete(filePath);
}
}4. 最后在前_添加 Ajax {用的代a:
//@里我使用了 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();
//接收返回的文件路,此文件@r已保存到服掌魃狭
if (data.fileName != "") {
//通^{用 window.location.href 直接跳D到下d action M行文件下d操作
window.location.href = "@Url.RouteUrl(new { Controller = "YourController", Action = "Download"})/?file=" + data.fileName;
}
});5. 完!
相关推荐
chongxiaocheng 2020-08-16
kentrl 2020-11-10
结束数据方法的参数,该如何定义?-- 集合为自定义实体类中的结合属性,有几个实体类,改变下标就行了。<input id="add" type="button" value="新增visitor&quo
ajaxyan 2020-11-09
zndy0 2020-11-03
学留痕 2020-09-20
learningever 2020-09-19
ajaxhe 2020-08-16
lyqdanang 2020-08-16
curiousL 2020-08-03
时光如瑾雨微凉 2020-07-19
坚持着执着 2020-07-16
jiaguoquan00 2020-07-07
李永毅 2020-07-05
坚持着执着 2020-07-05