asp.net core MVC 過濾器之ActionFilter過濾器(二)

來源:互聯網
上載者:User

標籤:log   addm   item   lin   原理   tor   代碼   cep   star   

本系類將會講解asp.net core MVC中的內建過濾器的使用,將分為以下章節

  asp.net core MVC 過濾器之ExceptionFilter過濾器(一)

  asp.net core MVC 過濾器之ActionFilter過濾器(二)

  asp.net core MVC 過濾器之ResultFilter過濾器(三)

  asp.net core MVC 過濾器之ResourceFilter過濾器(四)

  asp.net core MVC 過濾器之AuthorizationFilter過濾器(五)

簡介

Action過濾器將在controller的Action執行之前和之後執行相應的方法。

實現一個自訂Action過濾器

自訂一個全域異常過濾器需要實現IActionFilter介面

public class ActionFilter : IActionFilter{    public void OnActionExecuted(ActionExecutedContext context)    {        Console.WriteLine("action執行之後");    }    public void OnActionExecuting(ActionExecutingContext context)    {        Console.WriteLine("action執行之前");    }}

IActionFilter需要實現兩個方法OnActionExecuted,OnActionExecuting。OnActionExecuting將在Action之前執行,OnActionExecuted在Action之後執行。

知道原理之後我們們就可以利用其特性來簡化我們的代碼,在MVC中一個重要的概念就時Model驗證,我們定義Model約束,然後在Action中驗證Model是否綁定成功,我們的Action中重複地寫如下代碼

 

[HttpGet]public ActionResult Get(){    if (!ModelState.IsValid) return BadRequest("參數錯誤!");}

 這樣重複的代碼不僅增加代碼複雜都也不美觀,我們可以在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);}

當Model綁定錯誤時,我們拋出異常資訊,並在上一章節的異常過濾器ExceptionFilter中捕獲,返回錯誤資訊給請求方。

我們也可以利用ActionFilter的特性來記錄Action的執行時間,當Action執行時間過慢時輸出警告日誌

 

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}執行耗時:{time.ToString()}");        }    }    public void OnActionExecuting(ActionExecutingContext context)    {        var stopwach = new Stopwatch();        stopwach.Start();        context.HttpContext.Items.Add(Resources.StopwachKey, stopwach);    }}

上面的代碼利用使用HttpContext傳遞一個Stopwach來計算action的執行時間,並在超過5秒時輸出警告日誌。

 

註冊全域過濾器

註冊方法與ExceptionFinter相同。找到系統根目錄Startup.cs檔案,修改ConfigureServices方法如下

 services.AddMvc(options =>            {                options.Filters.Add<ActionFilter>();            });
 

asp.net core MVC 過濾器之ActionFilter過濾器(二)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.