ホームページ >ウェブフロントエンド >jsチュートリアル >Ajaxで生成してダウンロードしたExcelファイルの使用例

Ajaxで生成してダウンロードしたExcelファイルの使用例

高洛峰
高洛峰オリジナル
2016-12-06 10:31:131461ブラウズ

長い間記事を書いていませんでしたが、今日は Ajax を使用して ASP.NET MVC でファイルをダウンロードして生成する方法を共有します。以下は単なる私の個人的な経験です:

それは誰もが知っているはずです。 ASP.NET MVCでは、Ajax経由で呼び出した後、コントローラーを使用する場合、JSONオブジェクトを返すことができますが、ファイルを直接返すことはできません(ページを更新しない限り、Ajaxではありません)。そのため、Ajaxを使用したい場合は、ファイルを生成してダウンロードするには、まず生成されたファイルをサーバーに保存し、その後、ダウンロードする前にファイルのパスを JSON で返すだけです。ダウンロード後。

以下は Excel を動的に生成する方法の例です (Excel を生成する具体的な手順は省略しました。これはこの記事の焦点では​​ありません):

1. まず 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. ダウンロード用のアクションを作成します

[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. ダウンロード後にファイルを自動的に削除したいので、アクションフィルターを作成します

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: &#39;<h3>Please wait a moment...</h3>&#39; }); 
$.ajax({
  type: "POST",
  url: &#39;@Url.Action("ExportExcel","YourController")&#39;, //調用相應的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. 完了しました。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。