每個請求都會通過控制器處理,控制器中的每一個方法被稱爲控制器操做,它處理具體的請求。html
1操做輸入參數web
控制器的操做的輸入參數能夠是內置類型也能夠是自定義類型。編程
2操做返回結果緩存
結果類型安全 |
調用方法服務器 |
備註網絡 |
ContentResultmvc |
Content框架 |
文本類型asp.net |
FileContentResult/FileStreamResult/FilePathResult |
File |
文件類型 |
HttpStatusCodeResult(HttpNotFoundResult,HttpUnauthorizedResult)
|
HttpNotFound |
包含404,401狀態碼 |
|
|
|
JavaScriptResult |
JavaScript |
JavaScript代碼 |
JsonResult |
Json |
Json字符串 |
PartialViewResult |
PartialView |
部分視圖 |
RedirectResult |
Redirect/RedirectPermanent |
跳轉到給定URL |
RedirectToRouteResult |
RedirectToAction/RedirectToRoute |
重定向到指定的路由 |
ViewResult |
View |
指定視圖 |
EmptyResult |
無 |
不返回任何內容 |
上述返回值類型均繼承自ActionResult,除了上述類型外,控制器能夠返回任意的類型!
3 HTTP動詞特性
特性有HttpGet、HttpPost、HttpDelete、HttpPut、HttpHead、HttpOptions、HttpPatch,當沒有限定任何動詞時,不論何種請求,get,post,put等等,被請求的操做都會被調用。
4 操做過濾器
過濾器接口有
受權過濾器:public interface IAuthorizationFilter
動做過濾器:public interface IActionFilter
身份驗證過濾器:public interface IAuthenticationFilter
異常過濾器:public interface IExceptionFilter
結果過濾器:public interface IResultFilter
1)AuthorizeAttribute
public class AuthorizeAttribute : FilterAttribute, IAuthorizationFilter
AuthorizeAttribute的兩個經常使用屬性
Roles:獲取或設置有權訪問控制器或操做方法的用戶角色。
Users:獲取或設置有權訪問控制器或操做方法的用戶。
能夠在Web.config的<system.web>配置未經過驗證跳轉的頁面:
<authentication mode="Forms">
<forms loginUrl="~/Account/Login"></forms>
</authentication>
配合其使用的屬性
AllowAnonymous
public sealed class AllowAnonymousAttribute : Attribute
容許跳過AuthorizeAttribute的驗證執行控制器操做。
2)ChildActionOnlyAttribute
public sealed class ChildActionOnlyAttribute : FilterAttribute, IAuthorizationFilter
指示操做方法只能做爲子操做進行調用
例:
控制器
public class HomeController : Controller { [ChildActionOnly] public ActionResult TestPy() { return PartialView(); } }
分部視圖TestPy.cshtml:
<div> <h1>這是部分視圖</h1> </div>
調用頁Index.cshtml:
<div class="row"> <a href="@Url.Action("Home", "TestPy")">點擊調用分部視圖</a> </div>
執行報錯:404!
將調用頁代碼修改以下:
<div class="row"> @Html.Action("TestPy") </div>
運行能夠正常顯示部分視圖內容
3)RequireHttpsAttribute
public class RequireHttpsAttribute : FilterAttribute, IAuthorizationFilter
強制經過 HTTPS 從新發送不安全的 HTTP 請求
4)ValidateInputAttribute
public class ValidateInputAttribute : FilterAttribute, IAuthorizationFilter
驗證經過窗體傳進來的信息
5)ValidateAntiForgeryTokenAttribute
public sealed class ValidateAntiForgeryTokenAttribute : FilterAttribute, IAuthorizationFilter
阻止僞造請求
6)AsyncTimeoutAttribute
public class AsyncTimeoutAttribute : ActionFilterAttribute
設置異步操做超時時間
7)NoAsyncTimeoutAttribute
public sealed class NoAsyncTimeoutAttribute : AsyncTimeoutAttribute
設置異步操做永不超時
8)OutputCacheAttribute
public class OutputCacheAttribute : ActionFilterAttribute, IExceptionFilter
將緩存其輸出的操做方法
9)HandleErrorAttribute
public class HandleErrorAttribute : FilterAttribute, IExceptionFilter
處理由操做方法引起的異常
10)ActionNameAttribute
[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
public sealed class ActionNameAttribute : ActionNameSelectorAttribute
可使用此特性改變操做的名稱,使用新名稱做爲路由參數,方可路由到該操做
例:
[ActionName("AboutName")] public ActionResult About() { ...... }
11)NonActionAttribute
[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
public sealed class NonActionAttribute : ActionMethodSelectorAttribute
使用此特性修飾控制器操做,不會路由到此控制器方法
5向視圖傳遞數據
與其說傳遞數據,倒不如說視圖如何得到控制器處理過的數據。視圖經過兩種方式能夠拿到數據:
1)經過控制器操做返回的結果(控制器返回結果是數據和視圖的結合。
2)將結果賦給控制器屬性並在View中使用這些屬性。
public abstract class ControllerBase : IController
類中有三個屬性ViewData、ViewBag、TempData,使用着三個屬性向視圖傳遞數據。
ViewData
它是字典類型
public ViewDataDictionary ViewData { get; set; }
public class ViewDataDictionary : IDictionary<string, object>, ICollection<KeyValuePair<string, object>>, IEnumerable<KeyValuePair<string, object>>, IEnumerable
例:
第一種方式,弱類型
控制器
public ActionResult TestViewData() { ViewData["Field"] = "VD"; return View("Contact"); }
視圖Contact.cshtml
@ViewData["Field"]
在Index.cshtml視圖中調用
@Html.Action("TestViewData")
第二種方式,弱型別,使用ViewData.Model
這種方式沒法使用VS編譯器的智能提示功能
控制器
public ActionResult TestViewData() { ViewData.Model = new ModelF { Field="VD"}; return View("Contact"); }
視圖Contact.cshtml
@Model.Field
在Index.cshtml視圖中調用
@Html.Action("TestViewData")
第三種方式,強型別,使用ViewData.Model
控制器與第二種方式基本相同,不一樣點就是視圖Contact.cshtml
@model MVCPointApp.Models.ModelF
@Model.Field
ViewBag
它是動態類型,對ViewData的包裝
public dynamic ViewBag { get; }
例:
控制器操做中ViewBag.Field
使用@ViewBag.Message
TempData
它也是字典類型
public TempDataDictionary TempData { get; set; }
public class TempDataDictionary : IDictionary<string, object>, ICollection<KeyValuePair<string, object>>, IEnumerable<KeyValuePair<string, object>>, IEnumerable
6 異步控制器
原理:
ASP.NET從線程池得到線程處理異步請求,異步調用完後,該線程回到線程池以即可以處理其餘請求,同時通知ASP.NET從新抓取一個線程(不必定是處理異步請求的線程)來完成具體的異步操做(輸出數據等)。
使用異步控制器的目的:
異步控制器操做中也要等待任務直至處理完,因此處理速度不比同步方法快,其主要做用是高效地利用服務器資源。
使用異步控制器的情形:
可能引起瓶頸的長操做,網絡或I\O密集型操做,可取消長操做的情形。
構建異步控制器:
控制器繼承AsyncController,控制器操做返回Task<ActionResult>,並用async 修飾。
public class AnysController : AsyncController { // GET: Anys public async Task<ActionResult> Index() { //睡眠,模擬長任務 Thread.Sleep(5000000); return View("Testpy"); } }
7 擴展控制器
基類控制器
定義一個基類控制器,以便處理異常或沒法找到請求對應的操做。
注意若是控制器使用HttpPost特性修飾,而客戶端發起的是get請求,也會認爲是沒法找到操做。
例:
public class BaseController : Controller { protected override void OnException(ExceptionContext filterContext) { //錯誤日誌記錄 } protected override void HandleUnknownAction(string actionName) { //處理能找到此控制器,但找不到請求對應的操做 } }
擴展受權過濾器(AuthorizeAttribute)
具體示例見:驗證、受權與安全
動做過濾器(ActionFilterAttribute)
ActionFilterAttribute是一個抽象類,有四個方法:
操做執行後被框架自動調用的方法:OnActionExecuted
操做執行前被框架自動調用的方法:OnActionExecuting
返回結果後被框架自動調用的方法:OnResultExecuted
返回結果前被框架自動調用的方法:OnResultExecuting
參考:
1.Jess Chadwick/Todd Snyder/Hrusikesh Panda,徐雷/徐揚
譯。ASP.NET MVC4 Web編程
2.Jon Galloway/Phil Haack/Brad Wilson/K. Scott Allen,孫遠帥/鄒權譯 ASP.NET MVC4 高級編程(第四版)
3.黃保翕,ASP.NET MVC4開發指南
4.蔣金楠,ASP.NET MVC4框架揭祕
5.https://www.asp.net/mvc
-----------------------------------------------------------------------------------------
轉載與引用請註明出處。
時間倉促,水平有限,若有不當之處,歡迎指正。