這篇文章將為大家詳細(xì)講解有關(guān)asp.net中ActionFilter過濾器怎么用,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
威信ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18982081108(備注:SSL證書合作)期待與您的合作!
簡(jiǎn)介
Action過濾器將在controller的Action執(zhí)行之前和之后執(zhí)行相應(yīng)的方法。
實(shí)現(xiàn)一個(gè)自定義Action過濾器
自定義一個(gè)全局異常過濾器需要實(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)兩個(gè)方法OnActionExecuted,OnActionExecuting。OnActionExecuting將在Action之前執(zhí)行,OnActionExecuted在Action之后執(zhí)行。
知道原理之后我們們就可以利用其特性來簡(jiǎn)化我們的代碼,在MVC中一個(gè)重要的概念就時(shí)Model驗(yàn)證,我們定義Model約束,然后在Action中驗(yàn)證Model是否綁定成功,我們的Action中重復(fù)地寫如下代碼
[HttpGet] public ActionResult Get() { if (!ModelState.IsValid) return BadRequest("參數(shù)錯(cuò)誤!"); }
這樣重復(fù)的代碼不僅增加代碼復(fù)雜都也不美觀,我們可以在ActionFilter中自動(dòng)完成
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綁定錯(cuò)誤時(shí),我們拋出異常信息,并在上一章節(jié)的異常過濾器ExceptionFilter中捕獲,返回錯(cuò)誤信息給請(qǐng)求方。
我們也可以利用ActionFilter的特性來記錄Action的執(zhí)行時(shí)間,當(dāng)Action執(zhí)行時(shí)間過慢時(shí)輸出警告日志
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(); var logger = factory.CreateLogger (); logger.LogWarning($"{context.ActionDescriptor.DisplayName}執(zhí)行耗時(shí):{time.ToString()}"); } } public void OnActionExecuting(ActionExecutingContext context) { var stopwach = new Stopwatch(); stopwach.Start(); context.HttpContext.Items.Add(Resources.StopwachKey, stopwach); } }
上面的代碼利用使用HttpContext傳遞一個(gè)Stopwach來計(jì)算action的執(zhí)行時(shí)間,并在超過5秒時(shí)輸出警告日志。
注冊(cè)全局過濾器
注冊(cè)方法與ExceptionFinter相同。找到系統(tǒng)根目錄Startup.cs文件,修改ConfigureServices方法如下
services.AddMvc(options => { options.Filters.Add(); });
關(guān)于“asp.net中ActionFilter過濾器怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。