ASP.NET MVC中常用的ActionResult類型
常見的ActionResult
1、ViewResult
表示一個視圖結果,它根據視圖模板產生應答內容。對應得Controller方法為View。
2、PartialViewResult
表示一個部分視圖結果,與ViewResult本質上一致,只是部分視圖不支持母版,對應於ASP.NET,ViewResult相當於一個Page,而PartialViewResult 則相當於一個UserControl。它對應得Controller方法的PartialView.
3、RedirectResult
表示一個連接跳轉,相當於ASP.NET中的Response.Redirect方法,對應得Controller方法為Redirect。
4、RedirectToRouteResult
同樣表示一個跳轉,MVC會根據我們指定的路由名稱或路由信息(RouteValueDictionary)來生成Url地址,然後調用Response.Redirect跳轉。對應的Controller方法為RedirectToAction和RedirectToRoute.
5、ContentResult
返回簡單的純文本內容,可通過ContentType屬性指定應答文檔類型,通過ContentEncoding屬性指定應答文檔的字符編碼。可通過Controller類中的Content方法便捷地返回ContentResult對象。如果控制器方法返回非ActionResult對象,MVc將簡單地以返回對象的toString()內容為基礎產生一個ContentResult對象。
6、EmptyResult
返回一個空的結果,如果控制器方法返回一個null ,MVC將其轉換成EmptyResult對象。
7、JavaScriptResult
本質上是一個文本內容,只是將Response.ContentType設置為application/x-javascript,此結果應該和MicrosoftMvcAjax.js腳本配合使用,客戶端接收到Ajax應答後,將判斷Response.ContentType的值,如果是application/x-javascript,則直接eval 執行返回的應答內容,此結果類型對應得Controller方法為JavaScript.
8、JsonResult
表示一個Json結果。MVC將Response.ContentType 設置為application/json,並通過JavaScriptSerializer類指定對象序列化為Json表示方式。需要註意,默認情況下,Mvc不允許GET請求返回Json結果,要解除此限制,在生成JsonResult對象時,將其JsonRequestBehavior屬性設置為JsonRequestBehavior.AllowGet,此結果對應Controller方法的Json.
9、FileResult(FilePathResult、FileContentResult、FileStreamResult)
這三個類繼承於FileResult,表示一個文件內容,三者區別在於,FilePath 通過路徑傳送文件到客戶端,FileContent 通過二進制數據的方式,而FileStream 是通過Stream(流)的方式來傳送。Controller為這三個文件結果類型提供了一個名為File的重載方法。
FilePathResult: 直接將一個文件發送給客戶端
FileContentResult: 返回byte字節給客戶端(比如圖片)
FileStreamResult: 返回流
10、HttpUnauthorizedResult
表示一個未經授權訪問的錯誤,MVC會向客戶端發送一個401的應答狀態。如果在web.config 中開啟了表單驗證(authenication mode=”Forms”),則401狀態會將Url 轉向指定的loginUrl 鏈接。
11、HttpStatusCodeResult
返回一個服務器的錯誤信息
12、HttpNoFoundResult
返回一個找不到Action錯誤信息
// MVC 中的ActionResult是Action的返回結果. ActionResult有多個子類. // 並不是所有的子類都需要返回視圖View. // ActionResult是一個抽象類, 他定義了唯一的ExecuteResult方法, 參數為一個ControllerContext. // GET: Home public ActionResult Index() { return View(); } /// <summary> /// ContentResult用法(返回文本) /// http://localhost:30735/home/ContentResultDemo /// </summary> /// <returns>返回文本</returns> public ActionResult ContentResultDemo() { string str = "ContentResultDemo!"; return Content(str); } /// <summary> /// EmptyResult的用法(返回空對象) /// http://localhost:30735/home/EmptyResultDemo /// </summary> /// <returns>返回一個空對象</returns> public ActionResult EmptyResultDemo() { return new EmptyResult(); } /// <summary> /// FileContentResult的用法(返回圖片) /// http://localhost:30735/home/FileContentResultDemo /// </summary> /// <returns>顯示一個文件內容</returns> public ActionResult FileContentResultDemo() { FileStream fs = new FileStream(Server.MapPath(@"/Images/001.jpg"), FileMode.Open, FileAccess.Read); byte[] buffer = new byte[Convert.ToInt32(fs.Length)]; fs.Read(buffer, 0, Convert.ToInt32(fs.Length)); string contentType = "image/jpeg"; return File(buffer, contentType); } /// <summary> /// FilePathResult的用法(返回圖片) /// http://localhost:30735/home/FilePathResultDemo/002 /// </summary> /// <param name="id">圖片id</param> /// <returns>直接將返回一個文件對象</returns> public FilePathResult FilePathResultDemo(string id) { string path = Server.MapPath(@"/Images/" + id + ".jpg"); //定義內容類型(圖片) string contentType = "image/jpeg"; //FilePathResult直接返回file對象 return File(path, contentType); } /// <summary> /// FileStreamResult的用法(返回圖片) /// http://localhost:30735/home/FileStreamResultDemo /// </summary> /// <returns>返回文件流(圖片)</returns> public ActionResult FileStreamResultDemo() { FileStream fs = new FileStream(Server.MapPath(@"/Images/001.jpg"), FileMode.Open, FileAccess.Read); string contentType = "image/jpeg"; return File(fs, contentType); } /// <summary> /// HttpUnauthorizedResult 的用法(拋出401錯誤) /// http://localhost:30735/home/HttpUnauthorizedResult /// </summary> /// <returns></returns> public ActionResult HttpUnauthorizedResultDemo() { return new HttpUnauthorizedResult(); } /// <summary> /// HttpStatusCodeResult的方法(返回錯誤狀態信息) /// http://localhost:30735/home/HttpStatusCodeResult /// </summary> /// <returns></returns> public ActionResult HttpStatusCodeResultDemo() { return new HttpStatusCodeResult(500, "System Error"); } /// <summary> /// HttpNotFoundResult的使用方法 /// http://localhost:30735/home/HttpNotFoundResultDemo /// </summary> /// <returns></returns> public ActionResult HttpNotFoundResultDemo() { return new HttpNotFoundResult("not found action"); } /// <summary> /// JavaScriptResult 的用法(返回腳本文件) /// http://localhost:30735/home/JavaScriptResultDemo /// </summary> /// <returns>返回腳本內容</returns> public ActionResult JavaScriptResultDemo() { return JavaScript(@"<script>alert(‘Test JavaScriptResultDemo!‘)</script>"); } /// <summary> /// JsonResult的用法(返回一個json對象) /// http://localhost:30735/home/JsonResultDemo /// </summary> /// <returns>返回一個json對象</returns> public ActionResult JsonResultDemo() { var tempObj = new { Controller = "HomeController", Action = "JsonResultDemo" }; return Json(tempObj); } /// <summary> /// RedirectResult的用法(跳轉url地址) /// http://localhost:30735/home/RedirectResultDemo /// </summary> /// <returns></returns> public ActionResult RedirectResultDemo() { return Redirect(@"http://wwww.baidu.com"); } /// <summary> /// RedirectToRouteResult的用法(跳轉的action名稱) /// http://localhost:30735/home/RedirectToRouteResultDemo /// </summary> /// <returns></returns> public ActionResult RedirectToRouteResultDemo() { return RedirectToAction(@"FileStreamResultDemo"); } /// <summary> /// PartialViewResult的用法(返回部分視圖) /// http://localhost:30735/home/PartialViewResultDemo /// </summary> /// <returns></returns> public PartialViewResult PartialViewResultDemo() { return PartialView(); } /// <summary> /// ViewResult的用法(返回視圖) /// http://localhost:30735/home/ViewResultDemo /// </summary> /// <returns></returns> public ActionResult ViewResultDemo() { //如果沒有傳入View名稱, 默認尋找與Action名稱相同的View頁面. return View(); }
ASP.NET MVC中常用的ActionResult類型