asp.net core MVC 過濾器之ActionFilter過濾器(2)
簡介
Action過濾器將在controller的Action執(zhí)行之前和之后執(zhí)行相應(yīng)的方法。
實(shí)現(xiàn)一個自定義Action過濾器
自定義一個全局異常過濾器需要實(shí)現(xiàn)IActionFilter接口
public class ActionFilter : IActionFilter { public void OnActionExecuted(ActionExecutedContext context) { Console.WriteLine("action執(zhí)行之后"); } public void OnActionExecuting(ActionExecutingContext context) { Console.WriteLine("action執(zhí)行之前"); } }
IActionFilter需要實(shí)現(xiàn)兩個方法OnActionExecuted,OnActionExecuting。OnActionExecuting將在Action之前執(zhí)行,OnActionExecuted在Action之后執(zhí)行。
知道原理之后我們們就可以利用其特性來簡化我們的代碼,在MVC中一個重要的概念就時Model驗(yàn)證,我們定義Model約束,然后在Action中驗(yàn)證Model是否綁定成功,我們的Action中重復(fù)地寫如下代碼
[HttpGet] public ActionResult Get() { if (!ModelState.IsValid) return BadRequest("參數(shù)錯誤!"); }
這樣重復(fù)的代碼不僅增加代碼復(fù)雜都也不美觀,我們可以在ActionFilter中自動完成
public void OnActionExecuting(ActionExecutingContext context) { if (context.ModelState.IsValid) return; var modelState = context.ModelState.FirstOrDefault(f => f.Value.Errors.Any()); string errorMsg = modelState.Value.Errors.First().ErrorMessage; throw new AppException(errorMsg); }
當(dāng)Model綁定錯誤時,我們拋出異常信息,并在上一章節(jié)的異常過濾器ExceptionFilter中捕獲,返回錯誤信息給請求方。
我們也可以利用ActionFilter的特性來記錄Action的執(zhí)行時間,當(dāng)Action執(zhí)行時間過慢時輸出警告日志
public class ActionFilter : IActionFilter { public void OnActionExecuted(ActionExecutedContext context) { var httpContext = context.HttpContext; var stopwach = httpContext.Items[Resources.StopwachKey] as Stopwatch; stopwach.Stop(); var time = stopwach.Elapsed; if (time.TotalSeconds > 5) { var factory = context.HttpContext.RequestServices.GetService<ILoggerFactory>(); var logger = factory.CreateLogger<ActionExecutedContext>(); logger.LogWarning($"{context.ActionDescriptor.DisplayName}執(zhí)行耗時:{time.ToString()}"); } } public void OnActionExecuting(ActionExecutingContext context) { var stopwach = new Stopwatch(); stopwach.Start(); context.HttpContext.Items.Add(Resources.StopwachKey, stopwach); } }
上面的代碼利用使用HttpContext傳遞一個Stopwach來計(jì)算action的執(zhí)行時間,并在超過5秒時輸出警告日志。
注冊全局過濾器
注冊方法與ExceptionFinter相同。找到系統(tǒng)根目錄Startup.cs文件,修改ConfigureServices方法如下
services.AddMvc(options => { options.Filters.Add<ActionFilter>(); });
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Windows Server 2012 R2 或 2016無法安裝.Net 3.5.1
這篇文章主要為大家詳細(xì)介紹了Windows Server 2012 R2 或 2016 無法安裝 .Net 3.5.1,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02asp.net FileUpload控件實(shí)現(xiàn)文件格式判斷與文件大小限制
這篇文章主要介紹了有關(guān)asp.net fileupload控件判斷文件格式,以及進(jìn)行文件大小限制的方法,可以在web.config中配置,也可以在.cs文件中實(shí)現(xiàn),需要的朋友參考下2014-11-11asp.net core服務(wù)限制堆內(nèi)存大小的操作方法
asp.net core是微軟旗下支持跨平臺的開發(fā)框架,與springboot思想類似,支持ioc等,可以快速的開發(fā)web api等項(xiàng)目,這篇文章主要介紹了asp.net core服務(wù)限制堆內(nèi)存大小,需要的朋友可以參考下2022-09-09設(shè)置默認(rèn)Ajax操作cache and error
設(shè)置默認(rèn)Ajax操作cache and error,需要的朋友可以參考一下2013-02-02asp.net 分頁sql語句(結(jié)合aspnetpager)
一直用的是存儲過程分頁,小項(xiàng)目一般不寫存儲過程,就需要直接寫分頁sql語句。2009-01-01