真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

asp.net中ActionFilter過濾器怎么用-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)asp.net中ActionFilter過濾器怎么用,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)為您提適合企業(yè)的網(wǎng)站設(shè)計(jì)?讓您的網(wǎng)站在搜索引擎具有高度排名,讓您的網(wǎng)站具備超強(qiáng)的網(wǎng)絡(luò)競爭力!結(jié)合企業(yè)自身,進(jìn)行網(wǎng)站設(shè)計(jì)及把握,最后結(jié)合企業(yè)文化和具體宗旨等,才能創(chuàng)作出一份性化解決方案。從網(wǎng)站策劃到網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站, 我們的網(wǎng)頁設(shè)計(jì)師為您提供的解決方案。

簡介

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í)行。

知道原理之后我們們就可以利用其特性來簡化我們的代碼,在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中自動完成

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ò)誤信息給請求方。

我們也可以利用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í)輸出警告日志。

注冊全局過濾器

注冊方法與ExceptionFinter相同。找到系統(tǒng)根目錄Startup.cs文件,修改ConfigureServices方法如下

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

關(guān)于“asp.net中ActionFilter過濾器怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


當(dāng)前題目:asp.net中ActionFilter過濾器怎么用-創(chuàng)新互聯(lián)
轉(zhuǎn)載注明:http://weahome.cn/article/djhdph.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部