asp.net core MVC 過(guò)濾器之ActionFilter過(guò)濾器(2)
簡(jiǎn)介
Action過(guò)濾器將在controller的Action執(zhí)行之前和之后執(zhí)行相應(yīng)的方法。
實(shí)現(xiàn)一個(gè)自定義Action過(guò)濾器
自定義一個(gè)全局異常過(guò)濾器需要實(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í)行。
知道原理之后我們們就可以利用其特性來(lái)簡(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é)的異常過(guò)濾器ExceptionFilter中捕獲,返回錯(cuò)誤信息給請(qǐng)求方。
我們也可以利用ActionFilter的特性來(lái)記錄Action的執(zhí)行時(shí)間,當(dāng)Action執(zhí)行時(shí)間過(guò)慢時(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<ILoggerFactory>();
var logger = factory.CreateLogger<ActionExecutedContext>();
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來(lái)計(jì)算action的執(zhí)行時(shí)間,并在超過(guò)5秒時(shí)輸出警告日志。
注冊(cè)全局過(guò)濾器
注冊(cè)方法與ExceptionFinter相同。找到系統(tǒng)根目錄Startup.cs文件,修改ConfigureServices方法如下
services.AddMvc(options =>
{
options.Filters.Add<ActionFilter>();
});以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
.NET?6新特性試用之DateOnly和TimeOnly類型
這篇文章主要介紹了.NET?6新特性試用之DateOnly和TimeOnly類型,主要介紹DateOnly和TimeOnly類型使用過(guò)程及存在的一些過(guò)程,需要的小伙伴可以參考一下2022-03-03
IIS應(yīng)用池回收造成Application_Start中定時(shí)執(zhí)行程序停止的問(wèn)題的解決方法
最近在做一個(gè)項(xiàng)目,需要在程序中定時(shí)不斷的執(zhí)行某些操作,結(jié)果發(fā)現(xiàn)每天7,8點(diǎn)過(guò)后到第二天9點(diǎn),定時(shí)程序經(jīng)常都沒(méi)有在執(zhí)行,后來(lái)才知道由于IIS的應(yīng)用池回收導(dǎo)致Application停止。2010-03-03
asp.net轉(zhuǎn)出json格式客戶端顯示時(shí)間
最近在學(xué)習(xí)ext過(guò)程中,很多地方的數(shù)據(jù)從服務(wù)器傳到客戶端都是以json格式傳回來(lái)2008-10-10
Asp.net操作Excel更輕松的實(shí)現(xiàn)代碼
今天先介紹一個(gè)關(guān)于導(dǎo)出數(shù)據(jù)的例子,以Excel為模板。直接進(jìn)入正題了2011-10-10
詳解ASP.NET Core WebApi 返回統(tǒng)一格式參數(shù)
這篇文章主要介紹了詳解ASP.NET Core WebApi 返回統(tǒng)一格式參數(shù),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
Visual Studio(VS2017)配置C/C++ PostgreSQL9.6.3開(kāi)發(fā)環(huán)境
這篇文章主要為大家詳細(xì)介紹了Visual Studio(VS2017)配置C/C++,PostgreSQL9.6.3開(kāi)發(fā)環(huán)境,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
ASP.NET的HtmlForm控件學(xué)習(xí)及Post與Get的區(qū)別概述
HtmlForm 控件用于控制form元素,本文主要介紹下HtmlForm控件的Method/Action方法(要提交數(shù)據(jù)的頁(yè)面,即數(shù)據(jù)要傳送至哪個(gè)網(wǎng)址)及Post與Get的區(qū)別感興趣的朋友可以了解下,或許對(duì)你學(xué)習(xí)HtmlForm控件有所幫助2013-02-02
Visual Studio 2013更新內(nèi)容簡(jiǎn)介
這篇文章主要為大家分享了Visual Studio 2013更新內(nèi)容簡(jiǎn)介,感興趣的小伙伴們可以參考一下2016-05-05

